X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Finclude%2Fscore.hh;h=d4f26da4d22c5227b87aae787cf2e0904dda3fb1;hb=e172d5758ac4e3755640dac9374bd9e7ca0c6ed6;hp=364146883750a5042a82e3e6b83cf57f0cc4600b;hpb=04f01c7e890bd4f1b358378e5911fb7c117c3802;p=lilypond.git diff --git a/lily/include/score.hh b/lily/include/score.hh index 3641468837..d4f26da4d2 100644 --- a/lily/include/score.hh +++ b/lily/include/score.hh @@ -3,92 +3,47 @@ source file of the GNU LilyPond music typesetter - (c) 1997 Han-Wen Nienhuys + (c) 1997--2007 Han-Wen Nienhuys */ - #ifndef SCORE_HH #define SCORE_HH -#include "varray.hh" -#include "lily-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_; - Pointer_list staffs_; - - /// "runtime" fields for setting up spacing - Pointer_list rcols_; - - Pointer_list 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); - - /// 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 "input.hh" +#include "std-vector.hh" +#include "smobs.hh" +#include "virtual-methods.hh" + +class Score +{ + DECLARE_SMOBS (Score); + + SCM music_; + SCM input_location_; +public: + Input *origin() const; + + vector defs_; + string user_key_; + SCM header_; + 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 *); +}; - 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 */