]> git.donarmstrong.com Git - lilypond.git/blob - lily/include/score-element.hh
release: 1.3.9
[lilypond.git] / lily / include / score-element.hh
1 /*
2   score-element.hh -- declare Score_element
3
4   (c) 1996-1999 Han-Wen Nienhuys
5 */
6
7 #ifndef STAFFELEM_HH
8 #define STAFFELEM_HH
9
10 #include "parray.hh"
11 #include "virtual-methods.hh"
12 #include "graphical-element.hh"
13 #include "lily-guile.hh"
14 #include "smobs.hh"
15
16 typedef void (Score_element::*Score_element_method_pointer) (void);
17
18 /** Both Spanner and Item are Score_element's. Most Score_element's depend
19   on other Score_element's, eg, Beam needs to know and set direction of
20   Stem. So the Beam has to be calculated *before* Stem. This is
21   accomplished with the dependencies fields of struct Score_element,
22   which are implemented in the Directed_graph_node class: all elements
23   form an acyclic graph.
24
25   (elem)
26
27
28 Element Properties:
29
30 Boolean (true iff defined)
31
32  break_helper_only -- if defined try to junk this after calcing breakpoints.
33
34  transparent -- do not calc. output
35
36 */
37 class Score_element : public virtual Graphical_element {
38   /**
39      properties specific for this element. Destructor will not call
40      scm_unprotect, so as to allow more flexible GC arrangements.  The
41      real alist is in (cdr element_property_alist_), to reduce the
42      need for more scm_protect calls.
43
44   */
45   SCM element_property_alist_;
46   Link_array<Score_element> dependency_arr_;
47   /**
48      The lookup, determined by the font size. Cache this value.
49    */
50   Lookup * lookup_l_;
51 public:
52   Score_element *original_l_;
53
54   /**
55     Administration: Where are we?. This is mainly used by Super_element and
56     Score_element::calcalute_dependencies ()
57
58     0 means ORPHAN,
59     -1 means deleted
60     
61    */
62   int status_i_;
63
64   Paper_score *pscore_l_;
65   Molecule * output_p_;
66   Score_element ();
67   Score_element (Score_element const&);
68   virtual void print () const;
69
70   /*
71     properties
72    */
73   SCM get_elt_property (String nm) const;
74   void set_elt_property (String, SCM val);
75   SCM remove_elt_property (String nm);
76
77   /*
78     related classes.
79    */
80   Paper_def *paper_l () const;
81   Lookup const *lookup_l () const;
82
83   void add_processing ();
84
85   void substitute_dependency (Score_element*,Score_element*);
86   void remove_dependency (Score_element*);
87   /**
88     add a dependency. It may be the 0 pointer, in which case, it is ignored.
89     */
90   void add_dependency (Score_element*);    
91   virtual Line_of_score * line_l () const;
92   bool linked_b () const;
93   VIRTUAL_COPY_CONS(Score_element);
94  
95   /**
96      Recursively track all dependencies of this Score_element.  The
97      status_i_ field is used as a mark-field.  It is marked with
98      #busy# during execution of this function, and marked with #final#
99      when finished.
100
101      #funcptr# is the function to call to update this element.
102    */
103   void calculate_dependencies (int final, int busy, Score_element_method_pointer funcptr);
104
105   static SCM handle_broken_smobs (SCM, SCM criterion);
106
107   virtual Score_element *find_broken_piece (Line_of_score*) const;
108 protected:
109
110   /**
111     Junk score element. This is protected because this is supposed to
112     be handled by GUILE gc.  */
113   virtual ~Score_element ();
114   
115   Score_element* dependency (int) const;
116   int dependency_size () const;
117   
118   virtual void output_processing ();
119   virtual Interval do_height () const;
120   virtual Interval do_width () const;
121
122
123   /// do printing of derived info.
124   virtual void do_print () const;
125   /// generate the molecule    
126   virtual Molecule* do_brew_molecule_p () const;
127   ///executed directly after the item is added to the Paper_score
128   virtual void do_add_processing ();
129   /// do calculations before determining horizontal spacing
130   virtual void do_pre_processing ();
131
132   /// generate rods & springs
133   virtual void do_space_processing ();
134
135   virtual void do_breakable_col_processing ();
136   /// do calculations after determining horizontal spacing
137   virtual void do_post_processing ();
138     
139   virtual void do_substitute_element_pointer (Score_element * , Score_element *);
140   virtual void do_break_processing ();
141   virtual void handle_broken_dependencies ();
142   virtual void handle_prebroken_dependencies ();
143   virtual void handle_prebroken_dependents ();
144   virtual void handle_broken_dependents ();
145   virtual Link_array<Score_element> get_extra_dependencies () const;
146
147   static Interval dim_cache_callback (Dimension_cache const*);
148 public:
149
150   DECLARE_SMOBS;
151 };
152
153
154 template<class T>
155 void
156 substitute_element_array (Link_array<T> &arr, Line_of_score * to)
157 {
158   Link_array<T> newarr;
159   for (int i =0; i < arr.size (); i++)
160     {
161       T * t = arr[i];
162       if (t->line_l () != to)
163         {
164           t = dynamic_cast<T*> (t->find_broken_piece (to));
165         }
166       
167       if (t)
168         newarr.push (t);
169     }
170   arr = newarr;
171 }
172
173
174
175 #endif // STAFFELEM_HH
176