2021-11-30 04:31:32 +08:00
|
|
|
diff --git a/meson.build b/meson.build
|
2022-07-23 01:54:34 +08:00
|
|
|
index 7773f56..171d193 100644
|
2021-11-30 04:31:32 +08:00
|
|
|
--- a/meson.build
|
|
|
|
+++ b/meson.build
|
2022-07-23 01:54:34 +08:00
|
|
|
@@ -2089,42 +2089,10 @@ endif
|
2021-11-30 04:31:32 +08:00
|
|
|
# FIXME: glib-gettext.m4 has much more checks to detect broken/uncompatible
|
|
|
|
# implementations. This could be extended if issues are found in some platforms.
|
|
|
|
libintl_deps = []
|
2022-07-23 01:54:34 +08:00
|
|
|
-if cc.has_function('ngettext')
|
2021-11-30 04:31:32 +08:00
|
|
|
- have_bind_textdomain_codeset = cc.has_function('bind_textdomain_codeset')
|
|
|
|
-else
|
|
|
|
- # First just find the bare library.
|
|
|
|
- libintl = cc.find_library('intl', required : false)
|
|
|
|
- # The bare library probably won't link without help if it's static.
|
2022-07-23 01:54:34 +08:00
|
|
|
- if libintl.found() and not cc.has_function('ngettext', dependencies : libintl)
|
2021-11-30 04:31:32 +08:00
|
|
|
- libintl_iconv = cc.find_library('iconv', required : false)
|
|
|
|
- # libintl supports different threading APIs, which may not
|
|
|
|
- # require additional flags, but it defaults to using pthreads if
|
|
|
|
- # found. Meson's "threads" dependency does not allow you to
|
|
|
|
- # prefer pthreads. We may not be using pthreads for glib itself
|
|
|
|
- # either so just link the library to satisfy libintl rather than
|
|
|
|
- # also defining the macros with the -pthread flag.
|
|
|
|
- libintl_pthread = cc.find_library('pthread', required : false)
|
|
|
|
- # Try linking with just libiconv.
|
2022-07-23 01:54:34 +08:00
|
|
|
- if libintl_iconv.found() and cc.has_function('ngettext', dependencies : [libintl, libintl_iconv])
|
2021-11-30 04:31:32 +08:00
|
|
|
- libintl_deps += [libintl_iconv]
|
|
|
|
- # Then also try linking with pthreads.
|
2022-07-23 01:54:34 +08:00
|
|
|
- elif libintl_iconv.found() and libintl_pthread.found() and cc.has_function('ngettext', dependencies : [libintl, libintl_iconv, libintl_pthread])
|
2021-11-30 04:31:32 +08:00
|
|
|
- libintl_deps += [libintl_iconv, libintl_pthread]
|
|
|
|
- else
|
|
|
|
- libintl = disabler()
|
|
|
|
- endif
|
|
|
|
- endif
|
|
|
|
- if not libintl.found()
|
|
|
|
- libintl = subproject('proxy-libintl').get_variable('intl_dep')
|
|
|
|
- libintl_deps = [libintl] + libintl_deps
|
|
|
|
- have_bind_textdomain_codeset = true # proxy-libintl supports it
|
|
|
|
- else
|
|
|
|
- libintl_deps = [libintl] + libintl_deps
|
2022-07-23 01:54:34 +08:00
|
|
|
- have_bind_textdomain_codeset = cc.has_function('bind_textdomain_codeset',
|
|
|
|
- dependencies : libintl_deps)
|
2021-11-30 04:31:32 +08:00
|
|
|
- endif
|
|
|
|
-endif
|
|
|
|
-
|
2022-07-23 01:54:34 +08:00
|
|
|
+libintl = dependency('Intl', method:'cmake', required : true)
|
|
|
|
+libintl_deps += [libintl]
|
|
|
|
+have_bind_textdomain_codeset = cc.has_function('bind_textdomain_codeset',
|
|
|
|
+ dependencies : libintl_deps)
|
2021-11-30 04:31:32 +08:00
|
|
|
glib_conf.set('HAVE_BIND_TEXTDOMAIN_CODESET', have_bind_textdomain_codeset)
|
|
|
|
|
|
|
|
# We require gettext to always be present
|