]> git.donarmstrong.com Git - lilypond.git/blob - lily/axis-group-element.cc
a562b52d88d0b3254a62d5ef9af06bfbf779b5cd
[lilypond.git] / lily / axis-group-element.cc
1 /*
2   axis-group-element.cc -- implement Axis_group_element
3
4   source file of the GNU LilyPond music typesetter
5
6   (c)  1997--1999 Han-Wen Nienhuys <hanwen@cs.uu.nl>
7 */
8
9 #include "axis-group-element.hh"
10 #include "graphical-axis-group.hh"
11
12 Link_array<Score_element>
13 Axis_group_element::get_extra_dependencies() const
14 {
15   Link_array<Score_element> e(elem_l_arr ());
16   return e;
17 }
18
19 Link_array<Score_element>
20 Axis_group_element::elem_l_arr () const
21 {  
22   /*
23     ugh. I know
24   */
25   Link_array<Score_element> r;
26   for (int i=0; i < elem_l_arr_.size (); i++)
27     r.push (dynamic_cast<Score_element*>(elem_l_arr_[i]));
28       
29   return r;
30 }
31
32 Link_array<Score_element> 
33 Axis_group_element::get_children ()
34 {
35   Link_array<Score_element> childs;
36   Link_array<Score_element> elems = elem_l_arr ();
37   elems.concat (extra_elems_ );
38   for (int i=0; i < elems.size (); i++) 
39     {
40       Score_element* e = elems[i];
41       childs.push (e) ;
42       Axis_group_element * axis_group= dynamic_cast <Axis_group_element *> (e);
43       if (axis_group)
44         childs.concat (axis_group->get_children ());      
45     }
46   
47   return childs;
48 }
49
50 void
51 Axis_group_element::do_print() const
52 {
53   Graphical_axis_group::do_print();
54 }
55
56 Axis_group_element::Axis_group_element()
57 {
58   set_elt_property (transparent_scm_sym, SCM_BOOL_T);
59 }
60
61 void
62 Axis_group_element::set_axes (Axis a1, Axis a2)
63 {
64   Graphical_axis_group::set_axes (a1,a2);
65   dim_cache_[X_AXIS]->set_empty ((a1 != X_AXIS && a2 != X_AXIS));
66   dim_cache_[Y_AXIS]->set_empty ((a1 != Y_AXIS && a2 != Y_AXIS));
67 }
68
69
70 void
71 Axis_group_element::do_substitute_element_pointer (Score_element*o,
72                                                    Score_element*n)
73 {
74   int i;
75   Graphical_element * go = o;
76   Graphical_element * gn = n;  
77   
78   while ((i = elem_l_arr_.find_i (go))>=0)
79     elem_l_arr_.substitute (go,gn);
80 #if 0
81   if (n) 
82       elem_l_arr_[i] = n;
83     else
84       elem_l_arr_.del (i);
85 #endif
86   extra_elems_.substitute (o, n);
87 }
88
89 Interval
90 Axis_group_element::extra_extent (Axis a )const
91 {
92   Interval g;
93   purge_extra ();
94   for (int i=0;  i < extra_elems_.size (); i++)
95     {
96       Interval ge = extra_elems_[i]->extent (a);
97       ge += extra_elems_[i]->relative_coordinate (dim_cache_[a], a);
98       g.unite (ge);
99     }
100   return g;
101 }
102
103 Interval
104 Axis_group_element::do_height () const
105 {
106   Interval gag = Graphical_axis_group::extent (Y_AXIS);
107   gag.unite (extra_extent (Y_AXIS));
108   return gag;
109 }
110
111 Interval
112 Axis_group_element::do_width () const
113 {
114   Interval gag = Graphical_axis_group::extent (X_AXIS);
115   gag.unite (extra_extent (X_AXIS));
116   return gag;
117 }
118
119
120 /*
121   UGH.
122  */
123 void
124 Axis_group_element::add_extra_element (Score_element *e)
125 {
126   Link_array<Score_element> se;
127   while (e && e != this)
128     {
129       se.push (e);
130       e = dynamic_cast<Score_element*> (e->parent_l (Y_AXIS));
131     }
132
133   if (1)                        // e == this)
134     {
135       for (int i=0; i < se.size( ); i++) 
136         {
137           extra_elems_.push (se[i]);
138           add_dependency (se[i]);
139           se[i]->set_elt_property (ly_symbol ("Axis_group_element::add_extra_element"), SCM_BOOL_T); // UGH GUH.
140         }
141       
142     }
143 }
144
145 /*
146   UGH GUH
147  */
148 void
149 Axis_group_element::purge_extra ()
150 {
151   for (int i=0; i < extra_elems_.size ();)
152     {
153       Score_element *e = extra_elems_[i];
154       while (e && e != this)
155         {
156           e = dynamic_cast<Score_element*> (e->parent_l (Y_AXIS));
157         }
158       if (e != this)
159         extra_elems_.del (i);
160       else
161         i++;
162     }
163 }