meson: Use proxy-libintl subproject when needed and available

Such as on Windows with MSVC.
This commit is contained in:
Nirbheek Chauhan 2018-07-07 00:20:41 +05:30
parent de3e5be235
commit 00c29e1fbe

View File

@ -591,9 +591,24 @@ endif
# Check for bind_textdomain_codeset, including -lintl if GLib brings it in by # Check for bind_textdomain_codeset, including -lintl if GLib brings it in by
# doing the same check as glib. We can't check that by linking to glib because # doing the same check as glib. We can't check that by linking to glib because
# it might be a subproject and hence not built yet. # it might be a subproject and hence not built yet.
libintl_dep = cc.find_library('intl', required : false) if cc.has_function('ngettext')
if cc.has_function('bind_textdomain_codeset', dependencies: libintl_dep) libintl_dep = []
cdata.set('HAVE_BIND_TEXTDOMAIN_CODESET', 1) cdata.set('HAVE_BIND_TEXTDOMAIN_CODESET', 1)
else
libintl_dep = cc.find_library('intl', required : false)
if cc.has_function('bind_textdomain_codeset', dependencies: libintl_dep)
cdata.set('HAVE_BIND_TEXTDOMAIN_CODESET', 1)
else
# Don't use subproject('proxy-libintl').get_variable('intl_dep') because that
# makes the dependency unconditional. This way, people have the option of
# either not providing the subproject or disabling it entirely with
# --wrap-mode=nodownload or nofallback.
libintl_dep = dependency('', required : false,
fallback: ['proxy-libintl', 'intl_dep'])
if libintl_dep.found()
cdata.set('HAVE_BIND_TEXTDOMAIN_CODESET', 1)
endif
endif
endif endif
if os_unix if os_unix