X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Finclude%2Fscore.hh;h=7d4fa0142b96a08d2ee5000779f4ab42d1891e56;hb=e3d67c22f5f44859df86b9e3f1c26526a7f765dc;hp=cf86ad342a7a8ca4f28cf12398b98ccae8aa9dbf;hpb=a41a7fb966e8552cc8da7c4eab1b60eb7b8eff3a;p=lilypond.git diff --git a/lily/include/score.hh b/lily/include/score.hh index cf86ad342a..7d4fa0142b 100644 --- a/lily/include/score.hh +++ b/lily/include/score.hh @@ -1,90 +1,51 @@ /* 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--2008 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" - -/// 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 cols_; - PScore *pscore_p_; - - char const *defined_ch_C_; - 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); - - /// 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); +#include "lily-proto.hh" + +#include "input.hh" +#include "std-vector.hh" +#include "smobs.hh" +#include "virtual-methods.hh" + +class Score +{ + DECLARE_SMOBS (Score); + + SCM music_; + SCM input_location_; + SCM header_; +public: + Input *origin() const; + + vector defs_; + string user_key_; + bool error_found_; + + Score (); + Score (Score const &); + + VIRTUAL_COPY_CONSTRUCTOR (Score, Score); + + SCM get_music () const; + void add_output_def (Output_def *def); + void set_music (SCM music); + SCM book_rendering (Output_def *, Output_def *); + SCM get_header () const; + void set_header (SCM module); +}; - 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_render_output (SCM, SCM); +SCM ly_run_translator (SCM, SCM); - /// remove unused cols - void clean_cols(); - - /// add #Idealspacings# to #pscore_# - void calc_idealspacing(); -}; -#endif +#endif /* SCORE_HH */