From e6a5b88c01420366a70e0c9ae1775fb3c930cb8b Mon Sep 17 00:00:00 2001 From: Behdad Esfahbod Date: Thu, 5 May 2011 16:24:42 -0400 Subject: [PATCH] Fix build with older glib --- configure.ac | 2 +- test/hb-test.h | 55 ++++++++++++++++++++++++++++++-------------------- 2 files changed, 34 insertions(+), 23 deletions(-) diff --git a/configure.ac b/configure.ac index ad2d2bec3..e5147ca46 100644 --- a/configure.ac +++ b/configure.ac @@ -39,7 +39,7 @@ fi dnl ========================================================================== -PKG_CHECK_MODULES(GLIB, glib-2.0, have_glib=true, have_glib=false) +PKG_CHECK_MODULES(GLIB, glib-2.0 >= 2.16, have_glib=true, have_glib=false) if $have_glib; then AC_DEFINE(HAVE_GLIB, 1, [Have glib2 library]) fi diff --git a/test/hb-test.h b/test/hb-test.h index 73f8735c9..5f72a052e 100644 --- a/test/hb-test.h +++ b/test/hb-test.h @@ -123,9 +123,20 @@ hb_test_normalize_path (const char *path) } +#if GLIB_CHECK_VERSION(2,25,12) +typedef GTestFunc hb_test_func_t; +typedef GTestDataFunc hb_test_data_func_t; +typedef GTestFixtureFunc hb_test_fixture_func_t; +#else +typedef void (*hb_test_func_t) (void); +typedef void (*hb_test_data_func_t) (gconstpointer user_data); +typedef void (*hb_test_fixture_func_t) (gpointer fixture, + gconstpointer user_data); +#endif + static inline void hb_test_add_func (const char *test_path, - GTestFunc test_func) + hb_test_func_t test_func) { char *normal_path = hb_test_normalize_path (test_path); g_test_add_func (normal_path, test_func); @@ -136,7 +147,7 @@ hb_test_add_func (const char *test_path, static inline void hb_test_add_func_flavor (const char *test_path, const char *flavor, - GTestFunc test_func) + hb_test_func_t test_func) { char *path = g_strdup_printf ("%s/%s", test_path, flavor); hb_test_add_func (path, test_func); @@ -145,9 +156,9 @@ hb_test_add_func_flavor (const char *test_path, #define hb_test_add_flavor(Flavor, Func) hb_test_add_func (#Func, Flavor, Func) static inline void -hb_test_add_data_func (const char *test_path, - gconstpointer test_data, - GTestDataFunc test_func) +hb_test_add_data_func (const char *test_path, + gconstpointer test_data, + hb_test_data_func_t test_func) { char *normal_path = hb_test_normalize_path (test_path); g_test_add_data_func (normal_path, test_data, test_func); @@ -156,10 +167,10 @@ hb_test_add_data_func (const char *test_path, #define hb_test_add_data(UserData, Func) hb_test_add_data_func (#Func, UserData, Func) static inline void -hb_test_add_data_func_flavor (const char *test_path, - const char *flavor, - gconstpointer test_data, - GTestDataFunc test_func) +hb_test_add_data_func_flavor (const char *test_path, + const char *flavor, + gconstpointer test_data, + hb_test_data_func_t test_func) { char *path = g_strdup_printf ("%s/%s", test_path, flavor); hb_test_add_data_func (path, test_data, test_func); @@ -169,12 +180,12 @@ hb_test_add_data_func_flavor (const char *test_path, static inline void -hb_test_add_vtable (const char *test_path, - gsize data_size, - gconstpointer test_data, - GTestFixtureFunc data_setup, - GTestFixtureFunc data_test, - GTestFixtureFunc data_teardown) +hb_test_add_vtable (const char *test_path, + gsize data_size, + gconstpointer test_data, + hb_test_fixture_func_t data_setup, + hb_test_fixture_func_t data_test, + hb_test_fixture_func_t data_teardown) { char *normal_path = hb_test_normalize_path (test_path); g_test_add_vtable (normal_path, data_size, test_data, data_setup, data_test, data_teardown); @@ -196,13 +207,13 @@ G_STMT_START { \ } G_STMT_END static inline void -hb_test_add_vtable_flavor (const char *test_path, - const char *flavor, - gsize data_size, - gconstpointer test_data, - GTestFixtureFunc data_setup, - GTestFixtureFunc data_test, - GTestFixtureFunc data_teardown) +hb_test_add_vtable_flavor (const char *test_path, + const char *flavor, + gsize data_size, + gconstpointer test_data, + hb_test_fixture_func_t data_setup, + hb_test_fixture_func_t data_test, + hb_test_fixture_func_t data_teardown) { char *path = g_strdup_printf ("%s/%s", test_path, flavor); hb_test_add_vtable (path, data_size, test_data, data_setup, data_test, data_teardown);