X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Finclude%2Ffont-metric.hh;h=1107ba9af8e4d08fd6231f60f7ed2279078cbd0d;hb=66adac8fa4ba5126100ff8748a2576c6983637c5;hp=69e2033d973fa6a204d62d32acde231651c4e10f;hpb=cfbe7661413b152a10293f3da7fb412e325254f9;p=lilypond.git diff --git a/lily/include/font-metric.hh b/lily/include/font-metric.hh index 69e2033d97..1107ba9af8 100644 --- a/lily/include/font-metric.hh +++ b/lily/include/font-metric.hh @@ -3,7 +3,7 @@ source file of the GNU LilyPond music typesetter - (c) 1999--2005 Han-Wen Nienhuys + (c) 1999--2006 Han-Wen Nienhuys */ #ifndef FONT_METRIC_HH @@ -13,6 +13,12 @@ #include "lily-proto.hh" #include "smobs.hh" #include "virtual-methods.hh" +#include "freetype.hh" + +#include +using namespace std; + +typedef map Index_to_charcode_map; class Font_metric { @@ -20,26 +26,36 @@ class Font_metric public: SCM description_; - String file_name_; - - virtual Stencil text_stencil (String) const; - virtual Box text_dimension (String) const; - virtual String font_name () const; - virtual int count () const; - virtual Offset attachment_point (String) const; - virtual Offset get_indexed_wxwy (int) const; - virtual Box get_indexed_char (int index) const; - virtual Box get_ascii_char (int ascii) const; - virtual int name_to_index (String) const; - virtual unsigned index_to_charcode (int) const; - virtual int index_to_ascii (int) const; + string file_name_; + + virtual Stencil text_stencil (string) const; + virtual Stencil word_stencil (string) const; + + // ugh. + virtual Box text_dimension (string) const; + + virtual string font_name () const; + virtual size_t count () const; + virtual Offset attachment_point (string) const; + virtual Offset get_indexed_wxwy (size_t) const; + virtual Box get_indexed_char (size_t index) const; + virtual Box get_ascii_char (size_t ascii) const; + + /* + WTF are these vsize ? + + Font_metric is not related to vector<> + */ + virtual size_t name_to_index (string) const; + virtual size_t index_to_charcode (size_t) const; + virtual size_t index_to_ascii (size_t) const; virtual Real design_size () const; - virtual Stencil find_by_name (String) const; - virtual Stencil get_indexed_char_stencil (int k) const; - virtual Stencil get_ascii_char_stencil (int k) const; + virtual Stencil find_by_name (string) const; + virtual Stencil get_indexed_char_stencil (size_t k) const; + virtual Stencil get_ascii_char_stencil (size_t k) const; virtual SCM sub_fonts () const; virtual SCM font_file_name () const; - DECLARE_SMOBS (Font_metric,); + DECLARE_SMOBS (Font_metric); private: /* No copying, no implicit copy constructor. */ @@ -51,7 +67,7 @@ protected: Font_metric (); }; -int get_encoded_index (Font_metric *m, String input_coding, int code); +int get_encoded_index (Font_metric *m, string input_coding, int code); class Simple_font_metric : public Font_metric {