- /// paper_, staffs_ and commands_ form the problem definition.
- Paper_def *paper_p_;
- Midi_def *midi_p_;
- Music * music_p_;
-
-
- Pointer_list<Score_column*> cols_;
- PScore *pscore_p_;
-
- int errorlevel_i_;
-
- /* *************************************************************** */
-
- /// construction
- Score();
- ~Score();
-
- /// 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<Score_column *> find_col(Moment,bool);
-
- /// when does the last *musical* element finish?
- Moment last() const;
-
- Score(Score const&);
-
-private:
- void paper_output();
- void setup_music();
- /// do midi stuff
- void midi();
-
- /// do paper stuff
- void paper();
-
- // utils:
- PCursor<Score_column*> create_cols(Moment, PCursor<Score_column*> &last);
-
-
- /**
- make the pcol_l_ fields of each Score_column point to the correct PCol,
- remove any unnecessary Score_column's
- */
- void do_cols();
-
- /// remove unused cols
- void clean_cols();
-
- /// add #Idealspacings# to #pscore_#
- void calc_idealspacing();
+ Input *origin () const;
+
+ vector<Output_def *> defs_;
+ 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);