]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/include/tfm.hh
* scm/framework-ps.scm (write-preamble): embed CFFs if file name
[lilypond.git] / lily / include / tfm.hh
index 22e17c87cd14327aea5e47d6683d01517e04317b..32f1222589475a09b36ae0ab3ed274d95e26cf79 100644 (file)
@@ -1,14 +1,13 @@
-/*   
+/*
   tfm.hh -- declare Tex_font_metric
-  
+
   source file of the GNU LilyPond music typesetter
-  
-  (c) 1999--2000 Jan Nieuwenhuizen <janneke@gnu.org>
 
+  (c) 1999--2005 Jan Nieuwenhuizen <janneke@gnu.org>
 
-  revamped code from GNU Fontutils-0.6
 
- */
+  revamped code from GNU Fontutils-0.6
+*/
 
 /*
   TODO: aren't there standard libs?  Ideally it is better to just link
@@ -17,9 +16,7 @@
 #ifndef TFM_HH
 #define TFM_HH
 
-#include "string.hh"
 #include "array.hh"
-#include "lily-proto.hh"
 #include "font-metric.hh"
 
 /* The type.  */
@@ -131,39 +128,43 @@ struct Tfm_kern
 
 struct Tex_font_char_metric
 {
-  bool exists_b_;
+  bool exists_;
   Char_code code_;
   Real width_, height_, depth_, italic_correction_;
   Fix width_fix_, height_fix_, depth_fix_, italic_correction_fix_;
-  Array<Tfm_kern> kern_arr_;
-  Array<Tfm_ligature> ligature_arr_;
+  Array<Tfm_kern> kerns_;
+  Array<Tfm_ligature> ligatures_;
 
-  String str () const;
   Tex_font_char_metric ();
 
-  Box dimensions () const; 
+  Box dimensions () const;
 };
 
-
-class Tex_font_metric : public Font_metric
+class Tex_font_metric : public Simple_font_metric
 {
 public:
-  static  SCM make_tfm (String filename);
+  static SCM make_tfm (String file_name);
 
-  Box get_char (int) const;
-  Tex_font_char_metric const *find_ascii (int ascii, bool warn=true) const;
+  virtual int count () const;
+  virtual Box get_ascii_char (int) const;
+  virtual Real design_size () const;
+  virtual void derived_mark () const;
+  virtual int name_to_index (String) const;
+  virtual String font_name () const;
 
-  String str () const;
+  Tfm_info const &info () const;
 
-private:
-  Tex_font_metric ();
-  
+protected:
   Tfm_info info_;
   Tfm_header header_;
   Array<Tex_font_char_metric> char_metrics_;
   Array<int> ascii_to_metric_idx_;
+  SCM encoding_table_;
+  String font_name_;
+private:
+  Tex_font_char_metric const *find_ascii (int ascii, bool warn = true) const;
+  Tex_font_metric ();
 };
 
-
 #endif /* TFM_HH */