]> git.donarmstrong.com Git - lilypond.git/blob - lily/axis-group-engraver.cc
release: 1.3.56
[lilypond.git] / lily / axis-group-engraver.cc
1 /*   
2   axis-group-engraver.cc --  implement Axis_group_engraver
3   
4   source file of the GNU LilyPond music typesetter
5   
6   (c) 1999--2000 Han-Wen Nienhuys <hanwen@cs.uu.nl>
7  */
8
9 #include "axis-group-engraver.hh"
10 #include "spanner.hh"
11 #include "paper-column.hh"
12 #include "axis-group-interface.hh"
13 #include "dimension-cache.hh"
14 #include "engraver-group-engraver.hh"
15
16 Axis_group_engraver::Axis_group_engraver ()
17 {
18   staffline_p_ = 0;
19 }
20
21 void
22 Axis_group_engraver::do_creation_processing ()
23 {
24   staffline_p_ = get_spanner_p ();
25   Axis_group_interface (staffline_p_).set_interface ();
26   Axis_group_interface (staffline_p_).set_axes (Y_AXIS, Y_AXIS);
27   staffline_p_->set_bound(LEFT,get_staff_info().command_pcol_l ());
28   announce_element (Score_element_info (staffline_p_, 0));
29 }
30
31 Spanner*
32 Axis_group_engraver::get_spanner_p () const
33 {
34   return new Spanner (get_property ("basicVerticalAxisGroupProperties"));
35 }
36
37 void
38 Axis_group_engraver::do_removal_processing ()
39 {
40   String type = daddy_grav_l ()->type_str_ ;
41   SCM dims = get_property (type  + "VerticalExtent");
42   
43   if (gh_pair_p (dims) && gh_number_p (gh_car (dims))
44       && gh_number_p (gh_cdr (dims)))
45     {
46       staffline_p_->set_extent_callback (&Score_element::preset_extent, Y_AXIS);
47       staffline_p_->set_elt_property ("extent-Y", dims);
48     }
49
50   dims = get_property (type + "MinimumVerticalExtent");
51   if (gh_pair_p (dims) && gh_number_p (gh_car (dims))
52       && gh_number_p (gh_cdr (dims)))
53     staffline_p_->set_elt_property ("minimum-extent-Y", dims);
54
55   dims = get_property (type + "ExtraVerticalExtent");
56   if (gh_pair_p (dims) && gh_number_p (gh_car (dims))
57       && gh_number_p (gh_cdr (dims)))
58     staffline_p_->set_elt_property ("extra-extent-Y", dims);
59
60   
61   staffline_p_->set_bound(RIGHT,get_staff_info().command_pcol_l ());
62   typeset_element (staffline_p_);
63   staffline_p_ = 0;
64 }
65
66 void
67 Axis_group_engraver::acknowledge_element (Score_element_info i)
68 {
69   elts_.push (i.elem_l_);
70 }
71
72 void
73 Axis_group_engraver::process_acknowledged ()
74 {
75   /* UGH UGH UGH */
76   for (int i=0; i < elts_.size (); i++)
77     {
78       Score_element *par = elts_[i]->parent_l (Y_AXIS);
79
80       if ((!par || !Axis_group_interface (par).has_interface_b ())
81           && ! elts_[i]->empty_b (Y_AXIS))
82         Axis_group_interface (staffline_p_).add_element (elts_[i]);
83     }
84   elts_.clear ();
85 }
86
87 ADD_THIS_TRANSLATOR(Axis_group_engraver);