X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Ftext-interface.cc;h=983902f6af2079b97e586e2d6ab7eeeb752c225c;hb=96cc83632adc3af05556a39a36cc1553c000a108;hp=c7d425bcb5909f6afe205efa2db46ae97007582e;hpb=a640ea0e23770a906ec19eda0a67e556b49597fe;p=lilypond.git diff --git a/lily/text-interface.cc b/lily/text-interface.cc index c7d425bcb5..983902f6af 100644 --- a/lily/text-interface.cc +++ b/lily/text-interface.cc @@ -1,23 +1,34 @@ /* - text-interface.cc -- implement Text_interface + This file is part of LilyPond, the GNU music typesetter. - source file of the GNU LilyPond music typesetter - - (c) 1998--2009 Han-Wen Nienhuys + Copyright (C) 1998--2011 Han-Wen Nienhuys Jan Nieuwenhuizen + + LilyPond is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + LilyPond is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with LilyPond. If not, see . */ #include "text-interface.hh" - -#include "main.hh" #include "config.hh" -#include "pango-font.hh" -#include "warn.hh" -#include "grob.hh" #include "font-interface.hh" -#include "output-def.hh" +#include "grob.hh" +#include "main.hh" +#include "misc.hh" #include "modified-font-metric.hh" +#include "output-def.hh" +#include "pango-font.hh" +#include "warn.hh" static void replace_whitespace (string *str) @@ -27,24 +38,13 @@ replace_whitespace (string *str) while (i < n) { - vsize char_len = 1; char cur = (*str)[i]; - - // U+10000 - U+10FFFF - if ((cur & 0x11110000) == 0x11110000) - char_len = 4; - // U+0800 - U+FFFF - else if ((cur & 0x11100000) == 0x11100000) - char_len = 3; - // U+0080 - U+07FF - else if ((cur & 0x11000000) == 0x11000000) - char_len = 2; - else if (cur & 0x10000000) - programming_error ("invalid utf-8 string"); - else - // avoid the locale-dependent isspace - if (cur == '\n' || cur == '\t' || cur == '\v') - (*str)[i] = ' '; + + // avoid the locale-dependent isspace + if (cur == '\n' || cur == '\t' || cur == '\v') + (*str)[i] = ' '; + + vsize char_len = utf8_char_len (cur); i += char_len; } @@ -66,20 +66,17 @@ Text_interface::interpret_string (SCM layout_smob, replace_whitespace (&str); /* - We want to use "glyph-string" in the SVG backend for all - music fonts (Emmentaler and Aybabtu) that pass through the - text interface. Here the font encoding is checked to see if - it matches one of the music font encodings. --pmccarty + We want to filter strings with a music font that pass through + the text interface. Here the font encoding is checked to see + if it matches one of the music font encodings. --pmccarty */ SCM encoding = ly_chain_assoc_get (ly_symbol2scm ("font-encoding"), props, SCM_BOOL_F); SCM music_encodings = ly_lily_module_constant ("all-music-font-encodings"); - if (scm_memq (encoding, music_encodings) != SCM_BOOL_F) - return fm->word_stencil (str, true).smobbed_copy (); - else - return fm->word_stencil (str, false).smobbed_copy (); + bool is_music = (scm_memq (encoding, music_encodings) != SCM_BOOL_F); + return fm->text_stencil (layout, str, is_music).smobbed_copy (); } MAKE_SCHEME_CALLBACK_WITH_OPTARGS (Text_interface, interpret_markup, 3, 0,