]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/include/command-request.hh
release: 1.1.15
[lilypond.git] / lily / include / command-request.hh
index 3d5a1eb18d496d336700c1e2c873acad06d60060..81990b4f3f29f864aa343c42aeff569b068536e1 100644 (file)
@@ -1,9 +1,9 @@
 /*
-  command-request.hh -- declare Non musical requests
+  command-request.hh -- declare non-musical requests
 
-  source file of the LilyPond music typesetter
+  source file of the GNU LilyPond music typesetter
 
-  (c) 1997 Han-Wen Nienhuys <hanwen@stack.nl>
+  (c)  1997--1998 Han-Wen Nienhuys <hanwen@cs.uu.nl>
 */
 
 
 #define COMMANDREQUEST_HH
 
 #include "request.hh"
-#include "varray.hh"
+#include "array.hh"
+#include "duration.hh"
+#include "musical-pitch.hh"
 
 /** Request which are  assumed to be "happening" before the
-  musical requests. */
-struct Command_req : virtual Request {
-    REQUESTMETHODS(Command_req, command);
+  musical requests.  Not coupled to a note or rest. */
+class Command_req  : public virtual Request  {
+public:
+  REQUESTMETHODS(Command_req);
 
-    virtual Measure_grouping_req * measuregrouping() { return 0; }
-    virtual Clef_change_req * clefchange() { return 0; }
-    virtual Key_change_req * keychange() { return 0; }
-    virtual Partial_measure_req * partial() { return 0; }
-    virtual Meter_change_req * meterchange() { return 0; }
-    virtual Bar_req *bar() { return 0; }
-    virtual Cadenza_req *cadenza() { return 0; }
-    virtual Timing_req*timing() {  return 0; }
 };
 
 
-/** Baseclass for meter/partial req. It has to be handled by
+class Break_req : public Command_req {
+public:
+  enum { DISALLOW = -10000, FORCE = 10000 };
+  int penalty_i_;
+  Break_req ();
+  REQUESTMETHODS (Break_req);
+};
+
+class Mark_req : public Command_req {
+public:
+  Mark_req (String);
+  String str_;
+  REQUESTMETHODS (Mark_req);
+};
+
+class Command_script_req : public Command_req,  public Script_req {
+public:
+  // huh? 
+  Command_script_req();
+  ~Command_script_req();
+  REQUESTMETHODS(Command_script_req);
+};
+
+class Command_tie_req : public Command_req {
+public:
+  REQUESTMETHODS(Command_tie_req);
+};
+
+/** Baseclass for time_signature/partial req. It has to be handled by
   Staff_{walker,column} baseclass.  */
-struct Timing_req : Command_req {
-    REQUESTMETHODS(Timing_req, timing);
+class Timing_req  : public Command_req  {
+public:
+  REQUESTMETHODS(Timing_req);
 };
 
 
-struct Partial_measure_req : Timing_req {
-    Moment duration_;
+class Tempo_req : public Timing_req
+{
+public:
+  Duration dur_;
+  int metronome_i_;
+
+  Tempo_req();
+  REQUESTMETHODS(Tempo_req);
+  bool do_equal_b (Request *) const;
+};
+
+class Partial_measure_req  : public Timing_req  {
+public:
+  Moment duration_;
 
-    Partial_measure_req(Moment);
-    REQUESTMETHODS(Partial_measure_req, partial);
+  Partial_measure_req (Moment);
+  REQUESTMETHODS(Partial_measure_req);
+  bool do_equal_b (Request*) const;
 };
 
 /**
-  todo: allow C meter
+  todo: allow C time_signature
  */
-struct Meter_change_req : Timing_req {
-    int beats_i_, one_beat_i_;
+class Time_signature_change_req  : public Timing_req  {
+public:
+  int beats_i_, one_beat_i_;
 
-    Meter_change_req();
-    void set(int,int);
-    REQUESTMETHODS(Meter_change_req, meterchange);
+  Time_signature_change_req();
+  bool do_equal_b (Request*) const;
+  REQUESTMETHODS(Time_signature_change_req);
 };
 
 /// toggle Cadenza mode
-struct Cadenza_req : Timing_req {
-    /// turn on?
-    bool on_b_;
-    Cadenza_req(bool);
-    REQUESTMETHODS(Cadenza_req,cadenza);
+class Cadenza_req  : public Timing_req  {
+public:
+  /// turn on?
+  bool on_b_;
+  bool do_equal_b (Request*) const;
+  Cadenza_req (bool);
+  REQUESTMETHODS(Cadenza_req);
 };
 
 /// check if we're at start of a  measure.
-struct Barcheck_req : Timing_req {
-
-    REQUESTMETHODS(Barcheck_req,barcheck);
-};
-
-struct Measure_grouping_req: Timing_req {
-    Array<int> beat_i_arr_;
-    Array<Moment> elt_length_arr_;
-
-    REQUESTMETHODS(Measure_grouping_req, measuregrouping);
+class Barcheck_req  : public Timing_req  {
+public:
+  bool do_equal_b (Request *) const;
+  REQUESTMETHODS(Barcheck_req);
 };
 
-struct Group_change_req : Command_req {
-    String newgroup_str_;
-    REQUESTMETHODS(Group_change_req, groupchange);
+class Measure_grouping_req : public Timing_req  {
+public:
+  Array<int> beat_i_arr_;
+  Array<Moment> elt_length_arr_;
+  bool do_equal_b (Request *) const;
+  REQUESTMETHODS(Measure_grouping_req);
 };
 
 /** draw a (repeat)-bar. This something different than #Barcheck_req#,
   the latter should only happen at the start of a measure.  */
-struct Bar_req : Command_req {
-    String type_str_;
-    Bar_req(String);
-    int compare(const Bar_req&)const;
-    REQUESTMETHODS(Bar_req,bar);
-};
-struct Terminate_voice_req : Command_req {
-    REQUESTMETHODS(Terminate_voice_req,terminate);
-};
+class Bar_req  : public Command_req  {
+public:
+  String type_str_;
+  Bar_req (String);
+  bool do_equal_b (Request*) const;
 
-struct Group_feature_req : Command_req {
-    int stemdir_i_;
-    Group_feature_req();
-    REQUESTMETHODS(Group_feature_req, groupfeature);
+  REQUESTMETHODS(Bar_req);
 };
 
 
-struct Key_change_req : Command_req {
-    Array<Melodic_req*> melodic_p_arr_;
+/**
+    Handle key changes.
+    Routines for sharps and flats are separated, 
+    so that caller may identify non-conventional keys.
+*/
+class Key_change_req  : public Command_req  {
+public:
+  Array<Musical_pitch> pitch_arr_;
+  int modality_i_;
+  bool ordinary_key_b_;
+
+  Key_change_req();
+  REQUESTMETHODS(Key_change_req);
 
-    Key_change_req();
-    Key_change_req(Key_change_req const&);
-    ~Key_change_req();
-    REQUESTMETHODS(Key_change_req, keychange);
+  /// squash the octaves to 1
+  void squash_octaves();
+  /// return number of flats in key
+  int flats_i();
+
+  /// return number of sharps in key
+  int sharps_i();
+
+  void transpose (Musical_pitch  d);
+  bool minor_b() const;
+};
+
+class Clef_change_req  : public Command_req  {
+public:
+  String clef_str_;
+  Clef_change_req (String);
+  REQUESTMETHODS(Clef_change_req);
 };
 
-struct Clef_change_req : Command_req {
-    String clef_str_;
-    Clef_change_req(String);
-    REQUESTMETHODS(Clef_change_req, clefchange);
+class Bracket_req :  public Span_req, public Command_req {
+
+public:
+  REQUESTMETHODS(Bracket_req);
 };
 
+
 #endif // COMMANDREQUEST_HH