X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Finclude%2Fpaper-score.hh;h=7ec8fe8ce3c2f0af591533843f980cc8d9244ca3;hb=5b4b0d6e9a197e8f9eb085b7c2ad78b8be3e5cfc;hp=831f913e3ebbe2cc2f003b6368144ca3a7949c1d;hpb=fd58a98a46a3def26b80a895f1f7b81c92590fc3;p=lilypond.git diff --git a/lily/include/paper-score.hh b/lily/include/paper-score.hh index 831f913e3e..7ec8fe8ce3 100644 --- a/lily/include/paper-score.hh +++ b/lily/include/paper-score.hh @@ -3,57 +3,45 @@ source file of the GNU LilyPond music typesetter - (c) 1996--2003 Han-Wen Nienhuys + (c) 1996--2008 Han-Wen Nienhuys */ - -#ifndef P_SCORE_HH -#define P_SCORE_HH +#ifndef PAPER_SCORE_HH +#define PAPER_SCORE_HH #include "column-x-positions.hh" -#include "parray.hh" -#include "lily-proto.hh" #include "music-output.hh" -#include "lily-guile.hh" - -/** all stuff which goes onto paper. notes, signs, symbols in a score - #Paper_score# contains the items, the columns. - - */ +/* LAYOUT output */ class Paper_score : public Music_output { - SCM main_smob_; -public: - Paper_def *paper_; - - Paper_outputter *outputter_; + Output_def *layout_; System *system_; + SCM systems_; + SCM paper_systems_; + + mutable vector cols_; + mutable vector break_indices_; +public: + Paper_score (Output_def *); - Paper_score (); + DECLARE_CLASSNAME(Paper_score); - /** - @return index of argument. - */ - int find_col_idx (Paper_column const *) const; + Output_def *layout () const; + System *root_system () const; - Link_array broken_col_range (Item const*,Item const*) const; - void typeset_line (System*); - + void typeset_system (System *); + vector calc_breaking (); + vector find_break_indices () const; + vector get_break_indices () const; + vector get_columns () const; + SCM get_paper_systems (); protected: - /* MAIN ROUTINES */ - virtual void process (String); + virtual void process (); + virtual void derived_mark () const; private: - /// before calc_breaking - void preprocess (); - void calc_idealspacing (); - /// calculate where the lines are to be broken, and use results - Array calc_breaking (); - - /// after calc_breaking - void postprocess (); Paper_score (Paper_score const &); }; -#endif +#endif /* PAPER_SCORE_HH */