]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/ambitus.cc
Run `make grand-replace'.
[lilypond.git] / lily / ambitus.cc
index 43c9f0a01b6b5cb6f53f9bcaadf92078a2cd5c37..e123538dfa2df315e52cfc59b309bcf439489b6c 100644 (file)
@@ -3,7 +3,7 @@
 
   source file of the GNU LilyPond music typesetter
 
-  (c) 2002--2005 Juergen Reuter <reuter@ipd.uka.de>
+  (c) 2002--2008 Juergen Reuter <reuter@ipd.uka.de>
 */
 
 #include "ambitus.hh"
 #include "font-interface.hh"
 #include "output-def.hh"
 #include "lookup.hh"
-#include "group-interface.hh"
+#include "pointer-group-interface.hh"
 
 MAKE_SCHEME_CALLBACK (Ambitus, print, 1);
 SCM
 Ambitus::print (SCM smob)
 {
-  Item *me = (Item*) unsmob_grob (smob);
+  Item *me = (Item *) unsmob_grob (smob);
   Stencil stencil;
 
-  // join heads
-  Link_array<Grob> heads (extract_grob_array (me, ly_symbol2scm ("note-heads")));
+  // FIXME : should be Ambitus_line join heads
+  extract_grob_set (me, "note-heads", heads);
   if (to_boolean (me->get_property ("join-heads"))
-      && heads.size() > 1)
+      && heads.size () > 1)
     {
       Grob *common
-       = common_refpoint_of_array (heads.slice (0, 2), me, Y_AXIS);
+       = common_refpoint_of_array (vector<Grob*> (heads.begin (),
+                                                      heads.begin () + 2),
+                                   me, Y_AXIS);
 
       Grob *minh = heads[0];
       Grob *maxh = heads[1];
-      
-      if (minh->relative_coordinate (common, Y_AXIS) >
-         maxh->relative_coordinate (common, Y_AXIS))
+
+      if (minh->relative_coordinate (common, Y_AXIS)
+         maxh->relative_coordinate (common, Y_AXIS))
        {
          Grob *t = maxh;
          maxh = minh;
@@ -46,19 +48,19 @@ Ambitus::print (SCM smob)
       Real pad = 0.35;
       Real pmax = maxh->extent (common, Y_AXIS)[DOWN] - pad;
       Real pmin = minh->extent (common, Y_AXIS)[UP] + pad;
-      
+
       if (pmin < pmax)
        {
-         Real linethickness = me->get_layout ()->get_dimension (ly_symbol2scm ("linethickness"))
-           * robust_scm2double (me->get_property ("thickness"), 1.0); 
-         Real blotdiameter = me->get_layout ()->get_dimension (ly_symbol2scm ("blotdiameter"));
-         Interval x_extent = 0.5 * linethickness *Interval (-1, 1);
+         Real linethickness = me->layout ()->get_dimension (ly_symbol2scm ("line-thickness"))
+           * robust_scm2double (me->get_property ("thickness"), 1.0);
+         Real blotdiameter = me->layout ()->get_dimension (ly_symbol2scm ("blot-diameter"));
+         Interval x_extent = 0.5 * linethickness * Interval (-1, 1);
          Interval y_extent = Interval (pmin, pmax);
          Box line_box (x_extent, y_extent);
 
          Stencil line = Lookup::round_filled_box (line_box, blotdiameter);
-         line.translate_axis (- me-> relative_coordinate (common, Y_AXIS),
-                                  Y_AXIS);
+         line.translate_axis (- me->relative_coordinate (common, Y_AXIS),
+                              Y_AXIS);
          return line.smobbed_copy ();
        }
     }
@@ -66,6 +68,11 @@ Ambitus::print (SCM smob)
   return SCM_EOL;
 }
 
-ADD_INTERFACE (Ambitus, "ambitus-interface",
-  "The line between note heads for a pitch range.",
-  "thickness note-heads join-heads");
+ADD_INTERFACE (Ambitus,
+              "The line between note heads for a pitch range.",
+
+              /* properties */
+              "join-heads "
+              "note-heads "
+              "thickness "
+              );