[gjs/gnome-3-36] build: Handle missing /usr/bin/locale
- From: Philip Chimento <pchimento src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gjs/gnome-3-36] build: Handle missing /usr/bin/locale
- Date: Sat, 28 Mar 2020 05:49:50 +0000 (UTC)
commit 775452953f66e407742f7266f7cdec0524e9cd11
Author: Philip Chimento <philip chimento gmail com>
Date: Tue Mar 3 20:50:08 2020 -0800
build: Handle missing /usr/bin/locale
/usr/bin/locale is shipped by glibc, so for example on musl systems it
is missing. In this case, don't set the LC_ALL environment variable, and
hope for the best. (This also makes the change that LC_ALL is left
untouched on Windows, which seems better.)
Closes: #296
build/choose-tests-locale.sh | 4 ++++
meson.build | 19 ++++++++++---------
2 files changed, 14 insertions(+), 9 deletions(-)
---
diff --git a/build/choose-tests-locale.sh b/build/choose-tests-locale.sh
index ded42b99..73b273b8 100755
--- a/build/choose-tests-locale.sh
+++ b/build/choose-tests-locale.sh
@@ -1,5 +1,9 @@
#!/bin/sh
+if ! which locale > /dev/null; then
+ exit 1
+fi
+
locales=$(locale -a | xargs -n1)
case $locales in
diff --git a/meson.build b/meson.build
index 9d1ea722..d9c1867c 100644
--- a/meson.build
+++ b/meson.build
@@ -300,13 +300,6 @@ configure_file(output: 'config.h', configuration: header_conf)
### Check for environment ######################################################
-if cxx.get_id() == 'msvc'
- tests_locale = 'C.UTF-8'
-else
- # Not applicable for cmd.exe shells that MSVC uses
- tests_locale = run_command('build/choose-tests-locale.sh').stdout().strip()
-endif
-
gjsjsdir = get_option('datadir') / api_name
pkglibexecdir = get_option('libexecdir') / meson.project_name()
abs_pkglibexecdir = get_option('prefix') / pkglibexecdir
@@ -583,10 +576,18 @@ tests_environment.set('G_FILENAME_ENCODING', 'latin1')
tests_environment.set('LSAN_OPTIONS', 'exitcode=23,suppressions=@0@'.format(
meson.current_source_dir() / 'installed-tests' / 'extra' / 'lsan.supp'))
tests_environment.set('NO_AT_BRIDGE', '1')
-tests_environment.set('LC_ALL', tests_locale)
tests_environment.set('GSETTINGS_SCHEMA_DIR', js_tests_builddir)
tests_environment.set('G_DEBUG', 'fatal-warnings,fatal-criticals')
+tests_locale = 'N/A'
+if cxx.get_id() != 'msvc'
+ result = run_command('build/choose-tests-locale.sh')
+ if result.returncode() == 0
+ tests_locale = result.stdout().strip()
+ tests_environment.set('LC_ALL', tests_locale)
+ endif
+endif
+
if not get_option('skip_gtk_tests')
tests_environment.set('ENABLE_GTK', 'yes')
endif
@@ -650,7 +651,7 @@ gobject-introspection to run the tests. You can still build GJS, but some
tests will fail.''')
endif
-if tests_locale == 'C'
+if tests_locale == 'C' or tests_locale == 'N/A'
warning('''Your libc does not have the C.UTF-8 locale and no other
suitable UTF-8 fallback locale could be found. You can still build GJS, but
some tests will fail.''')
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]