Merge branch 'meson-system-libintl-detection' into 'main'

meson: Fix detection of a system-provided proxy-libintl

See merge request GNOME/glib!3352
This commit is contained in:
Philip Withnall 2023-04-14 15:50:20 +00:00
commit 715c8064be

View File

@ -2089,6 +2089,7 @@ libz_dep = dependency('zlib')
# FIXME: glib-gettext.m4 has much more checks to detect broken/uncompatible # FIXME: glib-gettext.m4 has much more checks to detect broken/uncompatible
# implementations. This could be extended if issues are found in some platforms. # implementations. This could be extended if issues are found in some platforms.
libintl_deps = [] libintl_deps = []
libintl_prefix = '#include <libintl.h>'
libintl = dependency('intl', required: false, allow_fallback: false) libintl = dependency('intl', required: false, allow_fallback: false)
if libintl.found() if libintl.found()
# libintl supports different threading APIs, which may not # libintl supports different threading APIs, which may not
@ -2100,11 +2101,11 @@ if libintl.found()
# #
# Meson's builtin dependency lookup as of 0.60.0 doesn't check for # Meson's builtin dependency lookup as of 0.60.0 doesn't check for
# pthread, so we do this manually here. # pthread, so we do this manually here.
if cc.has_function('ngettext', dependencies : libintl) if cc.has_function('ngettext', dependencies : libintl, prefix: libintl_prefix)
libintl_deps += [libintl] libintl_deps += [libintl]
else else
libintl_pthread = cc.find_library('pthread', required : false) libintl_pthread = cc.find_library('pthread', required : false)
if libintl_pthread.found() and cc.has_function('ngettext', dependencies : [libintl, libintl_pthread]) if libintl_pthread.found() and cc.has_function('ngettext', dependencies : [libintl, libintl_pthread], prefix: libintl_prefix)
libintl_deps += [libintl, libintl_pthread] libintl_deps += [libintl, libintl_pthread]
else else
libintl = disabler() libintl = disabler()
@ -2113,7 +2114,7 @@ if libintl.found()
endif endif
if libintl.found() if libintl.found()
have_bind_textdomain_codeset = cc.has_function('bind_textdomain_codeset', dependencies: libintl_deps) have_bind_textdomain_codeset = cc.has_function('bind_textdomain_codeset', dependencies: libintl_deps, prefix: libintl_prefix)
else else
libintl = dependency('intl', allow_fallback: true) libintl = dependency('intl', allow_fallback: true)
assert(libintl.type_name() == 'internal') assert(libintl.type_name() == 'internal')