]> git.donarmstrong.com Git - lilypond.git/blob - lily/script-column.cc
release: 1.3.62
[lilypond.git] / lily / script-column.cc
1 /*   
2   g-script-column.cc --  implement Script_column
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 "script-column.hh"
10 #include "side-position-interface.hh"
11 #include "dimension-cache.hh"
12 #include "group-interface.hh"
13
14 void
15 Script_column::add_staff_sided (Item *i)
16 {
17   SCM p = i->get_elt_property ("script-priority");
18   if (!gh_number_p (p))
19     return;
20   
21
22   Pointer_group_interface gi (this, "scripts");
23   gi.add_element (i);
24   
25   add_dependency (i);
26 }
27
28 Script_column::Script_column (SCM s)
29   : Item (s)
30 {
31   set_elt_pointer ("scripts", SCM_EOL);  
32 }
33
34 static int
35 staff_side_compare (Item * const &i1,
36                     Item * const &i2)
37 {
38   SCM p1 = i1->get_elt_property ("script-priority");
39   SCM p2 = i2->get_elt_property ("script-priority");
40
41   return gh_scm2int (p1) - gh_scm2int (p2);
42 }
43
44 GLUE_SCORE_ELEMENT(Script_column,before_line_breaking);
45 SCM
46 Script_column::member_before_line_breaking ()
47 {
48   Drul_array<Link_array<Item> > arrs;
49   Link_array<Item> staff_sided 
50     = Pointer_group_interface__extract_elements (this, (Item*)0, "scripts");
51                                      
52                                      
53   for (int i=0; i < staff_sided.size (); i++)
54     {
55       Side_position_interface st (staff_sided[i]);
56       arrs[st.get_direction ()].push (staff_sided[i]);
57     }
58
59   Direction d = DOWN;
60   do {
61     Link_array<Item> &arr(arrs[d]);
62     
63     arr.sort (staff_side_compare);
64
65     Item * last = 0;
66     for (int i=0; i < arr.size (); i++)
67       {
68         Side_position_interface s (arr[i]);
69         if (last)
70           {
71             s.add_support (last);
72           }
73             
74         arr[i]->remove_elt_property ("script-priority");
75         last = arr[i];
76       }
77     
78   } while (flip (&d) != DOWN);
79
80   return SCM_UNDEFINED;
81 }
82