]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/include/paper-def.hh
release: 1.3.6
[lilypond.git] / lily / include / paper-def.hh
index 4bf3b9589ca0b7594798f26bf72849d504d25486..b3147fb9e6da7d9d4e8c1f6bf456983f9728ef82 100644 (file)
@@ -3,18 +3,18 @@
 
   source file of the GNU LilyPond music typesetter
 
-  (c) 1996,1997 Han-Wen Nienhuys <hanwen@stack.nl>
+  (c) 1996, 1997--1999 Han-Wen Nienhuys <hanwen@cs.uu.nl>
 */
 
 
 #ifndef PAPER_DEF_HH
 #define PAPER_DEF_HH
 #include "lily-proto.hh"
-
+#include "lily-guile.hh"
 #include "real.hh"
 
 #include "moment.hh"
-#include "varray.hh"
+#include "array.hh"
 #include "interval.hh"
 #include "music-output-def.hh"
 
   
   add support for multiple fontsizes 
 
+  remove all utility funcs 
+  
+
   add support for other len->wid conversions.
 
-  Input_engraver should be in here.
- */
-class Paper_def : public Music_output_def {
-  Lookup *lookup_p_;
-  Dictionary<Real> *real_vars_p_;
+
+  Interesting variables:
+  
+  /// The distance between lines
+  interline
+  
+*/
+class Paper_def : public Music_output_def 
+{
+  Hash_table<int, Lookup *> *lookup_p_tab_p_;
   static int default_count_i_;
+
 protected:
-  VIRTUAL_COPY_CONS(Paper_def,Music_output_def);
+  VIRTUAL_COPY_CONS(Music_output_def);
+
 public:    
   virtual ~Paper_def ();
-  DECLARE_MY_RUNTIME_TYPEINFO;
 
   Array<Interval> shape_int_a_;
-
-  /**
-    Set or overwrite a variable
+  /*
+    JUNKME
    */
-  void set_var (String, Real);
-  /**
-    Read a variable.  Crash if it doesn't exist.
-   */
-  Real get_var (String) const;
+  Real get_realvar (SCM symbol) const;
+  Real get_var (String id) const;
+
+  
   void reinit ();
   Paper_def ();
-  void set (Lookup*);
+  void set_lookup (int, Lookup*);
 
   Paper_def (Paper_def const&);
-  /// The distance between beams
-  Real interbeam_f () const;
-  /**
-    The distance between lines
-    */
-  Real interline_f () const;
-  /// half the distance between lines
-  Real internote_f () const;
+  /** The distance between beams of multiplicity_i
+      JUNKME
+  */
+  Real interbeam_f (int multiplicity_i) const;
 
-  /// thickness of the standard line 
-  Real rule_thickness () const;
   Interval line_dimensions_int (int) const;
-  Real linewidth_f () const;
-  /// height of the staff
-  Real standard_height () const;
 
-  /// width of a crotchet ball
-  Real note_width () const;
   void print () const;
 
-  Lookup const * lookup_l ();  // TODO naming
+  Lookup const * lookup_l (int sz) const;      // TODO naming
 
   /** convert a duration to an idealspacing
-    influence using the geometric_ and  parameters.
+    influence using the geometric_ and  paratime_signatures.
     */
-  Real duration_to_dist (Moment, Real) const;
-  Real geometric_spacing (Moment) const;
+  Real length_mom_to_dist (Moment, Real) const;
+  
   Real arithmetic_constant (Moment minimal_mom) const;
   Real arithmetic_spacing (Moment mom,Real constant) const;
+
   virtual int get_next_default_count () const;
-  String TeX_output_settings_str () const;
+  static void reset_default_count();
+
+  void output_settings (Paper_outputter*) const;
+
+  Paper_stream* paper_stream_p () const;
+  String base_output_str () const;
+
+  // urg
+  friend int yyparse (void*);
 };
 
 #endif // Paper_def_HH
-