2 staff-elem.hh -- part of LilyPond
4 (c) 1996,97 Han-Wen Nienhuys
12 #include "molecule.hh"
13 #include "class-name.hh"
16 /** Both Spanner and Item are Staff_elem's. Most Staff_elem's depend
17 on other Staff_elem's, eg, Beam needs to know and set direction of
18 Stem. So the Beam has to be calculated *before* Stem. This is
19 accomplished with the dependencies field of struct Staff_elem.
25 /// member: the symbols
26 Molecule *output; // should scrap, and use temp var?
30 This is needed, because #output# may still be
34 Array<Staff_elem*> dependancy_l_arr_;
37 ORPHAN, // not yet added to pstaff
38 VIRGIN, // added to pstaff
40 PRECALCED, // calcs before spacing done
41 POSTCALCING, // busy calculating. This is used to trap cyclic deps.
42 POSTCALCED, // after spacing calcs done
43 OUTPUT, // molecule has been output
46 /// the pstaff it is in
50 Staff_elem(Staff_elem const&);
51 String TeXstring () const ;
52 virtual void print() const;
53 virtual Interval width() const;
54 virtual Interval height() const;
55 Paper_def *paper() const;
56 virtual ~Staff_elem();
58 NAME_MEMBERS(Staff_elem);
59 void translate(Offset);
60 void add_processing();
61 void pre_processing();
62 void post_processing();
63 void molecule_processing();
65 virtual Spanner* spanner() { return 0; }
66 virtual Item * item() { return 0; }
67 void add_dependency(Staff_elem* );
68 void substitute_dependency(Staff_elem* old, Staff_elem * newdep);
72 /// do printing of derived info.
73 virtual void do_print() const=0;
74 /// generate the molecule
75 virtual Molecule* brew_molecule_p()const=0;
76 ///executed directly after the item is added to the PScore
77 virtual void do_add_processing();
78 /// do calculations before determining horizontal spacing
79 virtual void do_pre_processing();
81 /// do calculations after determining horizontal spacing
82 virtual void do_post_processing();
84 Array<Staff_elem*> dependant_l_arr_;
89 #endif // STAFFELEM_HH