]> git.donarmstrong.com Git - lilypond.git/commitdiff
Pango: update interface for PangoContext and PangoFontMap.
authorPatrick McCarty <pnorcks@gmail.com>
Wed, 24 Feb 2010 03:09:47 +0000 (19:09 -0800)
committerPatrick McCarty <pnorcks@gmail.com>
Wed, 24 Feb 2010 04:27:16 +0000 (20:27 -0800)
The pango_ft2_get_context() function is deprecated.  Using
pango_context_new() followed by pango_context_set_font_map()
accomplishes the same task.

Fortunately, defining PANGO_ENABLE_BACKEND enables pango_context_new()
and pango_context_set_font_map() for Pango versions older than 1.22.

The recommended function, pango_font_map_create_context(), requires
Pango 1.22, so avoid using it unless we absolutely have to.

lily/pango-font.cc

index e2dd98b9f5d2f88acc5fbd7fe5719defc7ce1c62..a45c64f83001d05f95e779c48ab06795adb78c5e 100644 (file)
   along with LilyPond.  If not, see <http://www.gnu.org/licenses/>.
 */
 
-#define PANGO_ENABLE_BACKEND // ugh, why necessary?
+// Necessary for supporting pango_context_new() and
+// pango_context_set_font_map() in Pango < 1.22
+#define PANGO_ENABLE_BACKEND
+
 #include <pango/pangoft2.h>
 #include <freetype/ftxf86.h>
 
 #if HAVE_PANGO_FT2
 #include "stencil.hh"
 
-Pango_font::Pango_font (PangoFT2FontMap * /* fontmap */,
+Pango_font::Pango_font (PangoFT2FontMap *fontmap,
                        PangoFontDescription const *description,
                        Real output_scale)
 {
   physical_font_tab_ = scm_c_make_hash_table (11);
   PangoDirection pango_dir = PANGO_DIRECTION_LTR;
-  context_ = pango_ft2_get_context (PANGO_RESOLUTION,
-                                   PANGO_RESOLUTION);
+  context_ = pango_context_new ();
+  pango_context_set_font_map (context_, PANGO_FONT_MAP (fontmap));
 
   pango_description_ = pango_font_description_copy (description);
   attribute_list_ = pango_attr_list_new ();