summaryrefslogtreecommitdiff
path: root/cairo/cairo.dlsym.lcdfilter.patch
blob: 46f7ac74fd7aa181e63bc5096722db990555117b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
--- misc/cairo-1.10.2/src/cairo-ft-font.c	2012-01-06 09:09:21.500373823 +0000
+++ misc/build/cairo-1.10.2/src/cairo-ft-font.c	2012-01-06 09:31:01.645238786 +0000
@@ -59,6 +59,8 @@
 
 #if HAVE_FT_LIBRARY_SETLCDFILTER
 #include FT_LCD_FILTER_H
+#elif HAVE_DLFCN_H
+#include <dlfcn.h>
 #endif
 
 /* Fontconfig version older than 2.6 didn't have these options */
@@ -1217,6 +1219,26 @@
     return CAIRO_STATUS_SUCCESS;
 }
 
+static void try_FT_Library_SetLcdFilter( FT_Library library,
+    int lcd_filter )
+{
+#if HAVE_FT_LIBRARY_SETLCDFILTER
+    FT_Library_SetLcdFilter (library, lcd_filter);
+#elif HAVE_DLFCN_H
+    static void (*pFT_Library_SetLcdFilter) (FT_Library, int);
+    static int dlsymed = 0;
+
+    if (!dlsymed)
+    {
+        pFT_Library_SetLcdFilter = dlsym(RTLD_DEFAULT, "FT_Library_SetLcdFilter");
+        dlsymed = 1;
+    }
+
+    if (pFT_Library_SetLcdFilter)
+    	(*pFT_Library_SetLcdFilter) (library, lcd_filter); 
+#endif
+}
+
 /* Converts an outline FT_GlyphSlot into an image
  *
  * This could go through _render_glyph_bitmap as well, letting
@@ -1350,15 +1372,11 @@
 	    break;
 	    }
 
-#if HAVE_FT_LIBRARY_SETLCDFILTER
-	FT_Library_SetLcdFilter (library, lcd_filter);
-#endif
+	try_FT_Library_SetLcdFilter(library, lcd_filter);
 
 	fterror = FT_Render_Glyph (face->glyph, render_mode);
 
-#if HAVE_FT_LIBRARY_SETLCDFILTER
-	FT_Library_SetLcdFilter (library, FT_LCD_FILTER_NONE);
-#endif
+	try_FT_Library_SetLcdFilter(library, FT_LCD_FILTER_NONE);
 
 	if (fterror != 0)
 		return _cairo_error (CAIRO_STATUS_NO_MEMORY);