X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Finclude%2Fstem.hh;h=db82579fd30e5e62bcaf2aafa03f5da23c40d910;hb=e02ff353e9bbf2ac0924450770ac75eb88960aac;hp=41a8a78fe6e7268f2e118c7b0994ecac6bc13ae3;hpb=7d2ec0f1c47d211f243cf5646b35ef5298d8c82a;p=lilypond.git diff --git a/lily/include/stem.hh b/lily/include/stem.hh index 41a8a78fe6..db82579fd3 100644 --- a/lily/include/stem.hh +++ b/lily/include/stem.hh @@ -1,98 +1,50 @@ /* stem.hh -- declare Stem - (c) 1996--1999 Han-Wen Nienhuys + (c) 1996--2002 Han-Wen Nienhuys */ #ifndef STEM_HH #define STEM_HH -#include "item.hh" -#include "array.hh" -#include "moment.hh" -#include "molecule.hh" +#include "lily-proto.hh" +#include "lily-guile.hh" #include "stem-info.hh" +#include "drul-array.hh" -/**the rule attached to the ball. - takes care of: - - \begin{itemize} - \item the rule - \item the flag - \item up/down position. - \end{itemize} - - should move beam_{left, right} into Beam - - TODO. - - Stem size depends on flag. - - elt properties: - - beam_dir: direction of the beam (int) - - dir_force: is direction explicitely specified? (bool) - - /// how many abbrev beam don't reach stem? - int beam_gap_i_; - - - - */ -class Stem : public Item +class Stem { public: - /// log of the duration. Eg. 4 -> 16th note -> 2 flags - int flag_i () const; - - int beam_count (Direction) const; - void set_beaming (int, Direction d); - /** - don't print flag when in beam. - our beam, for aligning abbrev flags - */ - Beam* beam_l () const; - Note_head * first_head () const; - Drul_array extremal_heads () const; - - Score_element * support_head () const; - Stem (); - - /// ensure that this Stem also encompasses the Notehead #n# - void add_head (Rhythmic_head*n); - - Stem_info calc_stem_info () const; - - Real chord_start_f () const; - Direction get_direction () const; - int type_i () const; - void set_stemend (Real); - Direction get_default_dir() const; - - int get_center_distance(Direction) const; - int heads_i () const; - - bool invisible_b() const; - - /// heads that the stem encompasses (positions) - Interval head_positions() const; - -protected: - friend class Stem_tremolo; // ugh. - Real get_default_stem_end_position () const; - void position_noteheads(); - - - Real stem_end_position () const; - static Real off_callback (Dimension_cache const*); -protected: - Molecule flag () const; - - virtual void do_pre_processing(); - static Interval dim_callback (Dimension_cache const*); - virtual Molecule* do_brew_molecule_p() const; - - void set_spacing_hints () ; + DECLARE_SCHEME_CALLBACK (brew_molecule, (SCM )); + + static Array note_head_positions (Grob*); + static int duration_log (Grob*) ; + static void set_beaming (Grob*,int, Direction d); + static Grob * beam_l (Grob*); + static Grob * first_head (Grob*) ; + static Grob * last_head (Grob*) ; + static Drul_array extremal_heads (Grob*); + static Grob * support_head (Grob*) ; + static void add_head (Grob*me, Grob*n); + static Stem_info calc_stem_info (Grob *) ; + static Real chord_start_y (Grob *) ; + static Direction get_direction (Grob*) ; + static void set_stemend (Grob *,Real); + static Direction get_default_dir (Grob *) ; + static Slice Stem::beam_multiplicity (Grob *stem); + + static int head_count (Grob *) ; + static bool invisible_b (Grob *) ; + static Interval head_positions (Grob *) ; + static Real get_default_stem_end_position (Grob*me) ; + static void position_noteheads (Grob*); + static Real stem_end_position (Grob*) ; + DECLARE_SCHEME_CALLBACK (off_callback, (SCM element, SCM axis)); + static Molecule flag (Grob*); + DECLARE_SCHEME_CALLBACK (before_line_breaking, (SCM )); + DECLARE_SCHEME_CALLBACK (dim_callback, (SCM smob, SCM axis)); + DECLARE_SCHEME_CALLBACK (height, (SCM,SCM)); + static bool has_interface (Grob*); + static void set_spacing_hints (Grob*me) ; }; #endif