X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Finclude%2Fscore.hh;h=0f015a0139fbba775cc9b5ee863869b8817b9cc7;hb=9dfba39d593ac445518023d03a4d9726f924530e;hp=e83540533b60aff0e26e0ecd7274209e616bc836;hpb=c8989177a23864cfa3d44e013585e719b816acfd;p=lilypond.git diff --git a/lily/include/score.hh b/lily/include/score.hh index e83540533b..0f015a0139 100644 --- a/lily/include/score.hh +++ b/lily/include/score.hh @@ -1,94 +1,39 @@ /* score.hh -- declare Score - source file of the LilyPond music typesetter + source file of the GNU LilyPond music typesetter - (c) 1997 Han-Wen Nienhuys + (c) 1997--2004 Han-Wen Nienhuys */ - #ifndef SCORE_HH #define SCORE_HH -#include "varray.hh" -#include "proto.hh" -#include "plist.hh" -#include "moment.hh" -#include "assoc.hh" -#include "string.hh" -#include "input.hh" #include "lily-proto.hh" -/// the total music def of one movement -struct Score { - /// paper_, staffs_ and commands_ form the problem definition. - Paper_def *paper_p_; - Midi_def *midi_p_; - IPointerList staffs_; - - /// "runtime" fields for setting up spacing - IPointerList rcols_; - - IPointerList cols_; - PScore *pscore_p_; - - Input input_; - int errorlevel_i_; - - /* *************************************************************** */ - - /// construction - Score(); - ~Score(); - void add(Staff*); - - /// do everything except outputting to file - void process(); - - /// output to file - void output(String fn); - - - /// - void set(Midi_def* midi_p); - /// - void set(Paper_def* midi_p); - - // standard - void OK() const; - void print() const; - - /// find a column. - PCursor find_col(Moment,bool); +#include "input.hh" +#include "parray.hh" +#include "smobs.hh" +#include "virtual-methods.hh" + +class Score : public Input +{ + DECLARE_SMOBS (Score, foo); + +public: + Link_array defs_; + SCM music_; + SCM header_; - /// when does the last *musical* element finish? - Moment last() const; - -private: - void paper_output(); - void setup_music(); - void process_music(); - /// do midi stuff - void midi(); - - /// do paper stuff - void paper(); - - // utils: - PCursor create_cols(Moment, PCursor &last); + Score (); + Score (Score const&); + SCM book_rendering (String, Output_def*, Output_def*); +}; - Score(Score const&){} +DECLARE_UNSMOB (Score, score); - /** - make the pcol_l_ fields of each Score_column point to the correct PCol, - remove any unnecessary Score_column's - */ - void do_cols(); +SCM ly_run_translator (SCM, SCM); +SCM ly_render_output (SCM, SCM); +void default_rendering (SCM, SCM, SCM, SCM, SCM); - /// remove unused cols - void clean_cols(); - - /// add #Idealspacings# to #pscore_# - void calc_idealspacing(); -}; -#endif +#endif /* SCORE_HH */