]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/stem.cc
Documentation/user/programming-interface.itely: fix @{ @}.
[lilypond.git] / lily / stem.cc
index 028843a6eb7257c0d58e5a04cbe66832a8301231..f258b7aedad25edd22db88d73c4b426d1a7ce226 100644 (file)
@@ -28,7 +28,7 @@
 #include "misc.hh"
 #include "beam.hh"
 #include "rest.hh"
-#include "group-interface.hh"
+#include "pointer-group-interface.hh"
 #include "staff-symbol-referencer.hh"
 #include "side-position-interface.hh"
 #include "dot-column.hh"
@@ -47,7 +47,7 @@ Stem::set_beaming (Grob *me, int beam_count, Direction d)
 
   SCM lst = index_get_cell (pair, d);
   for (int i = 0; i < beam_count; i++)
-    lst = scm_cons (scm_int2num (i), lst);
+    lst = scm_cons (scm_from_int (i), lst);
   index_set_cell (pair, d, lst);
 }
 
@@ -92,7 +92,7 @@ Stem::stem_end_position (Grob *me)
   if (!scm_is_number (p))
     {
       pos = get_default_stem_end_position (me);
-      me->set_property ("stem-end-position", scm_make_real (pos));
+      me->set_property ("stem-end-position", scm_from_double (pos));
     }
   else
     pos = scm_to_double (p);
@@ -121,9 +121,9 @@ Stem::set_stemend (Grob *me, Real se)
   Direction d = get_direction (me);
 
   if (d && d * head_positions (me)[get_direction (me)] >= se * d)
-    me->warning (_ ("Weird stem size; check for narrow beams"));
+    me->warning (_ ("weird stem size, check for narrow beams"));
 
-  me->set_property ("stem-end-position", scm_make_real (se));
+  me->set_property ("stem-end-position", scm_from_double (se));
 }
 
 /* Note head that determines hshift for upstems
@@ -131,9 +131,10 @@ Stem::set_stemend (Grob *me, Real se)
 Grob *
 Stem::support_head (Grob *me)
 {
-  if (head_count (me) == 1)
-    /* UGH. */
-    return unsmob_grob (scm_car (me->get_property ("note-heads")));
+  extract_grob_set (me, "note-heads", heads);
+  if (heads.size () == 1)
+    return heads[0];
+  
   return first_head (me);
 }
 
@@ -178,10 +179,11 @@ Stem::extremal_heads (Grob *me)
   extpos[UP] = -inf;
 
   Drul_array<Grob *> exthead (0, 0);
-  for (SCM s = me->get_property ("note-heads"); scm_is_pair (s);
-       s = scm_cdr (s))
+  extract_grob_set (me, "note-heads", heads);
+  
+  for (int i = heads.size (); i--;)
     {
-      Grob *n = unsmob_grob (scm_car (s));
+      Grob *n = heads[i];
       int p = Staff_symbol_referencer::get_rounded_position (n);
 
       Direction d = LEFT;
@@ -209,10 +211,11 @@ Array<int>
 Stem::note_head_positions (Grob *me)
 {
   Array<int> ps;
-  for (SCM s = me->get_property ("note-heads"); scm_is_pair (s);
-       s = scm_cdr (s))
+  extract_grob_set (me, "note-heads", heads);
+  
+  for (int i = heads.size (); i--;)
     {
-      Grob *n = unsmob_grob (scm_car (s));
+      Grob *n = heads[i];
       int p = Staff_symbol_referencer::get_rounded_position (n);
 
       ps.push (p);
@@ -225,7 +228,7 @@ Stem::note_head_positions (Grob *me)
 void
 Stem::add_head (Grob *me, Grob *n)
 {
-  n->set_property ("stem", me->self_scm ());
+  n->set_object ("stem", me->self_scm ());
   n->add_dependency (me);
 
   if (Note_head::has_interface (n))
@@ -298,7 +301,7 @@ Stem::get_default_stem_end_position (Grob *me)
     {
       SCM sshorten = me->get_property ("stem-shorten");
       SCM scm_shorten = scm_is_pair (sshorten)
-       ? robust_list_ref ((duration_log (me) - 2) >? 0, sshorten) : SCM_EOL;
+       ? robust_list_ref (max (duration_log (me) - 2, 0), sshorten) : SCM_EOL;
       Real shorten = 2* robust_scm2double (scm_shorten, 0);
 
       /* On boundary: shorten only half */
@@ -309,8 +312,8 @@ Stem::get_default_stem_end_position (Grob *me)
     }
 
   /* Tremolo stuff.  */
-  Grob *t_flag = unsmob_grob (me->get_property ("tremolo-flag"));
-  if (t_flag && !unsmob_grob (me->get_property ("beam")))
+  Grob *t_flag = unsmob_grob (me->get_object ("tremolo-flag"));
+  if (t_flag && !unsmob_grob (me->get_object ("beam")))
     {
       /* Crude hack: add extra space if tremolo flag is there.
 
@@ -332,7 +335,7 @@ Stem::get_default_stem_end_position (Grob *me)
          if (dir == DOWN)
            minlen -= 1.0;
        }
-      length = length >? (minlen + 1.0);
+      length = max (length, minlen + 1.0);
     }
 
   Real st = dir ? hp[dir] + dir * length : 0;
@@ -391,9 +394,8 @@ Stem::position_noteheads (Grob *me)
   if (!head_count (me))
     return;
 
-  Link_array<Grob> heads
-    = extract_grob_array (me, ly_symbol2scm ("note-heads"));
-
+  extract_grob_set (me, "note-heads", ro_heads);
+  Link_array<Grob> heads (ro_heads);
   heads.sort (compare_position);
   Direction dir = get_direction (me);
 
@@ -516,7 +518,7 @@ Stem::height (SCM smob, SCM ax)
       Direction d = get_direction (me);
       if (d == CENTER)
        {
-         programming_error ("No stem direction");
+         programming_error ("no stem direction");
          d = UP;
        }
       iv[d] += d * Beam::get_thickness (b) * 0.5;
@@ -598,8 +600,8 @@ MAKE_SCHEME_CALLBACK (Stem, width_callback, 2);
 SCM
 Stem::width_callback (SCM e, SCM ax)
 {
-  Axis a = (Axis) scm_to_int (ax);
-  assert (a == X_AXIS);
+  (void) ax;
+  assert (scm_to_int (ax) == X_AXIS);
   Grob *me = unsmob_grob (e);
 
   Interval r;
@@ -608,15 +610,15 @@ Stem::width_callback (SCM e, SCM ax)
     {
       r.set_empty ();
     }
-  else if (unsmob_grob (me->get_property ("beam")) || abs (duration_log (me)) <= 2)
+  else if (unsmob_grob (me->get_object ("beam")) || abs (duration_log (me)) <= 2)
     {
       r = Interval (-1, 1);
       r *= thickness (me) / 2;
     }
   else
     {
-      r = flag (me).extent (X_AXIS)
-       + thickness (me) / 2;
+      r = Interval (-1,1) * thickness (me) * 0.5;
+      r.unite (flag (me).extent (X_AXIS));
     }
   return ly_interval2scm (r);
 }
@@ -671,11 +673,11 @@ Stem::print (SCM smob)
 
       y2 -= d
        * (0.5 * beam_thickness
-          + beam_translation * (0 >? (beam_count - 1))
+          + beam_translation * max (0, (beam_count - 1))
           + stemlet_length) / half_space;
     }
 
-  Interval stem_y (y1 <? y2, y2 >? y1);
+  Interval stem_y (min (y1, y2), max (y2, y1));
 
   if (Grob *hed = support_head (me))
     {
@@ -744,20 +746,20 @@ Stem::offset_callback (SCM element_smob, SCM)
     }
   else
     {
-      SCM rests = me->get_property ("rests");
-      if (scm_is_pair (rests))
+      extract_grob_set (me, "rests", rests);
+      if (rests.size ())
        {
-         Grob *rest = unsmob_grob (scm_car (rests));
+         Grob *rest = rests.top ();
          r = rest->extent (rest, X_AXIS).center ();
        }
     }
-  return scm_make_real (r);
+  return scm_from_double (r);
 }
 
 Spanner *
 Stem::get_beam (Grob *me)
 {
-  SCM b = me->get_property ("beam");
+  SCM b = me->get_object ("beam");
   return dynamic_cast<Spanner *> (unsmob_grob (b));
 }
 
@@ -787,7 +789,7 @@ Stem::calc_stem_info (Grob *me)
 
   if (!my_dir)
     {
-      programming_error ("No stem dir set?");
+      programming_error ("no stem dir set");
       my_dir = UP;
     }
 
@@ -828,7 +830,7 @@ Stem::calc_stem_info (Grob *me)
     /* stem only extends to center of beam */
     - 0.5 * beam_thickness;
 
-  ideal_length = ideal_length >? ideal_minimum_length;
+  ideal_length = max (ideal_length, ideal_minimum_length);
 
   /* Convert to Y position, calculate for dir == UP */
   Real note_start
@@ -858,10 +860,10 @@ Stem::calc_stem_info (Grob *me)
     {
       /* Highest beam of (UP) beam must never be lower than middle
         staffline */
-      ideal_y = ideal_y >? 0;
+      ideal_y = max (ideal_y, 0.0);
       /* Lowest beam of (UP) beam must never be lower than second staffline */
-      ideal_y = ideal_y >? (-staff_space
-                           - beam_thickness + height_of_my_beams);
+      ideal_y = max (ideal_y, (-staff_space
+                              - beam_thickness + height_of_my_beams));
     }
 
   ideal_y -= robust_scm2double (beam->get_property ("shorten"), 0);
@@ -878,13 +880,20 @@ Stem::calc_stem_info (Grob *me)
     /* stem only extends to center of beam */
     - 0.5 * beam_thickness;
 
+  if (Grob *tremolo = unsmob_grob (me->get_object ("tremolo-flag")))
+    {
+      Interval y_ext = tremolo->extent (tremolo, Y_AXIS);
+      y_ext.widen (0.5);       // FIXME. Should be tunable? 
+      minimum_length = max (minimum_length, y_ext.length ());
+    }
+  
   ideal_y *= my_dir;
   Real minimum_y = note_start + minimum_length;
   Real shortest_y = minimum_y * my_dir;
 
   me->set_property ("stem-info",
-                   scm_list_2 (scm_make_real (ideal_y),
-                               scm_make_real (shortest_y)));
+                   scm_list_2 (scm_from_double (ideal_y),
+                               scm_from_double (shortest_y)));
 }
 
 Slice