diff --git a/.github/scripts/build_projects.py b/.github/scripts/build_projects.py
index 85de1284..d30723cc 100755
--- a/.github/scripts/build_projects.py
+++ b/.github/scripts/build_projects.py
@@ -6,9 +6,11 @@
make_archive,
create_desktop_image,
fix_macos_rpath,
+ upload_archive,
OS_NAME,
PLATFORM_TARGET,
DESKTOP,
+ DEV_BRANCH,
)
if (PLATFORM_TARGET.startswith("android_")
@@ -32,14 +34,18 @@
TARGETS = ("kiwix-tools",)
elif PLATFORM_TARGET == "flatpak":
TARGETS = ("kiwix-desktop",)
+elif PLATFORM_TARGET == "wasm":
+ TARGETS = ("libzim", )
else:
TARGETS = ("libzim", "zim-tools", "libkiwix", "kiwix-tools")
for target in TARGETS:
run_kiwix_build(target, platform=PLATFORM_TARGET)
if target == "kiwix-desktop":
- create_desktop_image(make_release=False)
+ archive = create_desktop_image(make_release=False)
else:
if PLATFORM_TARGET == "native_mixed" and OS_NAME == "osx":
fix_macos_rpath(target)
- make_archive(target, make_release=False)
+ archive = make_archive(target, make_release=False)
+ if archive:
+ upload_archive(archive, target, make_release=False, dev_branch=DEV_BRANCH)
diff --git a/.github/scripts/build_release_nightly.py b/.github/scripts/build_release_nightly.py
index 5907ac8e..407efe94 100755
--- a/.github/scripts/build_release_nightly.py
+++ b/.github/scripts/build_release_nightly.py
@@ -38,6 +38,8 @@
TARGETS = ("kiwix-tools",)
elif PLATFORM_TARGET == "flatpak":
TARGETS = ("kiwix-desktop",)
+elif PLATFORM_TARGET == "wasm":
+ TARGETS = ("libzim", )
else:
TARGETS = ("libzim", "zim-tools", "libkiwix", "kiwix-tools")
diff --git a/.github/scripts/common.py b/.github/scripts/common.py
index 1f9d3074..67b8d462 100644
--- a/.github/scripts/common.py
+++ b/.github/scripts/common.py
@@ -39,6 +39,11 @@
MAKE_RELEASE = re.fullmatch(r"r_[0-9]+", _ref) is not None
MAKE_RELEASE = MAKE_RELEASE and (_environ.get('GITHUB_EVENT_NAME') != 'schedule')
+if not MAKE_RELEASE and _ref != "master":
+ DEV_BRANCH = _ref
+else:
+ DEV_BRANCH = None
+
RELEASE_OS_NAME = "macos" if OS_NAME == "osx" else "linux"
PLATFORM_TO_RELEASE = {
@@ -51,13 +56,7 @@
"android_arm64": "android-arm64",
"android_x86": "android-x86",
"android_x86_64": "android-x86_64",
-}
-
-LIB_PREFIX = {
- "android_arm": "arm-linux-androideabi",
- "android_arm64": "aarch64-linux-android",
- "android_x86": "i686-linux-android",
- "android_x86_64": "x86_64-linux-android",
+ "wasm": "wasm-emscripten",
}
FLATPAK_HTTP_GIT_REMOTE = "https://github.com/flathub/org.kiwix.desktop.git"
@@ -94,15 +93,12 @@
"libzim": (
INSTALL_DIR,
(
- "lib/{libprefix}/libzim.so".format(
- libprefix=LIB_PREFIX.get(PLATFORM_TARGET, "x86_64-linux-gnu"),
- ),
- "lib/{libprefix}/libzim.so.{version}".format(
- libprefix=LIB_PREFIX.get(PLATFORM_TARGET, "x86_64-linux-gnu"),
+ "lib/*/libzim.a",
+ "lib/*/libzim.so",
+ "lib/*/libzim.so.{version}".format(
version=main_project_versions["libzim"]
),
- "lib/{libprefix}/libzim.so.{version}".format(
- libprefix=LIB_PREFIX.get(PLATFORM_TARGET, "x86_64-linux-gnu"),
+ "lib/*/libzim.so.{version}".format(
version=main_project_versions["libzim"][0]
),
"lib/libzim.{}.dylib".format(
@@ -115,15 +111,11 @@
"libkiwix": (
INSTALL_DIR,
(
- "lib/{libprefix}/libkiwix.so".format(
- libprefix=LIB_PREFIX.get(PLATFORM_TARGET, "x86_64-linux-gnu"),
- ),
- "lib/{libprefix}/libkiwix.so.{version}".format(
- libprefix=LIB_PREFIX.get(PLATFORM_TARGET, "x86_64-linux-gnu"),
+ "lib/*/libkiwix.so",
+ "lib/*/libkiwix.so.{version}".format(
version=main_project_versions["libkiwix"]
),
- "lib/{libprefix}/libkiwix.so.{version}".format(
- libprefix=LIB_PREFIX.get(PLATFORM_TARGET, "x86_64-linux-gnu"),
+ "lib/*/libkiwix.so.{version}".format(
version=main_project_versions["libkiwix"][0]
),
"include/kiwix/**/*.h"
@@ -240,7 +232,7 @@ def upload(file_to_upload, host, dest_path):
subprocess.check_call(command)
-def upload_archive(archive, project, make_release):
+def upload_archive(archive, project, make_release, dev_branch=None):
if not archive.exists():
print_message("No archive {} to upload!", archive)
return
@@ -257,9 +249,12 @@ def upload_archive(archive, project, make_release):
else:
dest_path = dest_path + "nightly/" + DATE
- # Make the archive read only. This way, scp will preserve rights.
- # If somehow we try to upload twice the same archive, scp will fails.
- archive.chmod(0o444)
+ if dev_branch:
+ dest_path = "/data/tmp/ci/" + dev_branch
+ else:
+ # Make the archive read only. This way, scp will preserve rights.
+ # If somehow we try to upload twice the same archive, scp will fails.
+ archive.chmod(0o444)
upload(archive, host, dest_path)
@@ -280,6 +275,7 @@ def make_deps_archive(target=None, name=None, full=False):
if (base_dir / "meson_cross_file.txt").exists():
files_to_archive.append(base_dir / "meson_cross_file.txt")
files_to_archive += HOME.glob("BUILD_*/android-ndk*")
+ files_to_archive += HOME.glob("BUILD_*/emsdk*")
if (BASE_DIR / "meson_cross_file.txt").exists():
files_to_archive.append(BASE_DIR / "meson_cross_file.txt")
diff --git a/.github/scripts/compile_all_deps.py b/.github/scripts/compile_all_deps.py
index f7d471da..c690af17 100755
--- a/.github/scripts/compile_all_deps.py
+++ b/.github/scripts/compile_all_deps.py
@@ -14,6 +14,8 @@
if PLATFORM_TARGET.startswith("android_") or PLATFORM_TARGET.startswith("iOS"):
TARGETS = ("libzim", "libkiwix")
+elif PLATFORM_TARGET == "wasm":
+ TARGETS = ("libzim", )
elif PLATFORM_TARGET.startswith("native_"):
if OS_NAME == "osx":
TARGETS = ("libzim", "zim-tools", "libkiwix")
diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml
index d67c2c8f..bf630e08 100644
--- a/.github/workflows/ci.yml
+++ b/.github/workflows/ci.yml
@@ -38,6 +38,7 @@ jobs:
- native_dyn
- native_mixed
- native_desktop
+ - wasm
- armhf_static
- armhf_dyn
- i586_static
diff --git a/kiwixbuild/buildenv.py b/kiwixbuild/buildenv.py
index 3d86bc3e..97719cf8 100644
--- a/kiwixbuild/buildenv.py
+++ b/kiwixbuild/buildenv.py
@@ -148,3 +148,21 @@ def get_env(self, *, cross_comp_flags, cross_compilers, cross_path):
if cross_path:
env['PATH'] = ':'.join(self.platformInfo.get_bin_dir() + [env['PATH']])
return env
+
+
+ @property
+ def configure_wrapper(self):
+ wrapper = getattr(self.platformInfo, "configure_wrapper", "")
+ if wrapper:
+ return "{} ".format(wrapper)
+ else:
+ return ""
+
+ @property
+ def make_wrapper(self):
+ wrapper = getattr(self.platformInfo, "make_wrapper", "")
+ if wrapper:
+ return "{} ".format(wrapper)
+ else:
+ return ""
+
diff --git a/kiwixbuild/dependencies/__init__.py b/kiwixbuild/dependencies/__init__.py
index caf695dc..70d5de86 100644
--- a/kiwixbuild/dependencies/__init__.py
+++ b/kiwixbuild/dependencies/__init__.py
@@ -6,6 +6,7 @@
aria2,
armhf,
docoptcpp,
+ emsdk,
flatpak,
gumbo,
icu4c,
diff --git a/kiwixbuild/dependencies/all_dependencies.py b/kiwixbuild/dependencies/all_dependencies.py
index 0be910cc..f2bfd461 100644
--- a/kiwixbuild/dependencies/all_dependencies.py
+++ b/kiwixbuild/dependencies/all_dependencies.py
@@ -12,6 +12,9 @@ class AllBaseDependencies(Dependency):
class Builder(NoopBuilder):
@classmethod
def get_dependencies(cls, platformInfo, allDeps):
+ if platformInfo.build == "wasm":
+ return ['zlib', 'lzma', 'zstd', 'icu4c', 'xapian-core']
+
base_deps = ['zlib', 'lzma', 'zstd', 'xapian-core', 'pugixml', 'libcurl', 'icu4c', 'mustache', 'libmicrohttpd', 'zim-testing-suite']
# Add specific dependencies depending of the platform
if platformInfo.build not in ('android', 'iOS'):
diff --git a/kiwixbuild/dependencies/base.py b/kiwixbuild/dependencies/base.py
index 2601ea81..16886238 100644
--- a/kiwixbuild/dependencies/base.py
+++ b/kiwixbuild/dependencies/base.py
@@ -70,8 +70,9 @@ def _log_dir(self):
def _patch(self, context):
context.try_skip(self.source_path)
for p in self.patches:
- with open(pj(SCRIPT_DIR, 'patches', p), 'r') as patch_input:
- run_command("patch -p1", self.source_path, context, input=patch_input.read())
+ patch_file_path = pj(SCRIPT_DIR, 'patches', p)
+ patch_command = "patch -p1 -i {patch}".format(patch=patch_file_path)
+ run_command(patch_command, self.source_path, context)
def command(self, name, function, *args):
print(" {} {} : ".format(name, self.name), end="", flush=True)
@@ -339,7 +340,7 @@ class MakeBuilder(Builder):
@property
def make_install_target(self):
- if self.buildEnv.platformInfo.build == 'iOS':
+ if self.buildEnv.platformInfo.build in ('iOS', "wasm"):
return 'install'
return 'install-strip'
@@ -368,8 +369,9 @@ def set_configure_env(self, env):
def _configure(self, context):
context.try_skip(self.build_path)
- command = "{configure_script} {configure_option}"
+ command = "{configure_wrapper}{configure_script} {configure_option}"
command = command.format(
+ configure_wrapper=self.buildEnv.configure_wrapper,
configure_script=pj(self.source_path, self.configure_script),
configure_option=self.all_configure_option
)
@@ -379,7 +381,8 @@ def _configure(self, context):
def _compile(self, context):
context.try_skip(self.build_path)
- command = "make -j4 {make_target} {make_option}".format(
+ command = "{make_wrapper}make -j4 {make_target} {make_option}".format(
+ make_wrapper=self.buildEnv.make_wrapper,
make_target=self.make_target,
make_option=self.make_option
)
@@ -388,7 +391,8 @@ def _compile(self, context):
def _install(self, context):
context.try_skip(self.build_path)
- command = "make {make_install_target} {make_option}".format(
+ command = "{make_wrapper}make {make_install_target} {make_option}".format(
+ make_wrapper=self.buildEnv.make_wrapper,
make_install_target=self.make_install_target,
make_option=self.make_option
)
@@ -397,7 +401,9 @@ def _install(self, context):
def _make_dist(self, context):
context.try_skip(self.build_path)
- command = "make dist"
+ command = "{make_wrapper}make dist".format(
+ make_wrapper=self.buildEnv.make_wrapper
+ )
env = self.get_env(cross_comp_flags=True, cross_compilers=True, cross_path=True)
run_command(command, self.build_path, context, env=env)
diff --git a/kiwixbuild/dependencies/emsdk.py b/kiwixbuild/dependencies/emsdk.py
new file mode 100644
index 00000000..bd7c2834
--- /dev/null
+++ b/kiwixbuild/dependencies/emsdk.py
@@ -0,0 +1,47 @@
+import os
+
+from .base import Dependency, ReleaseDownload, Builder
+from kiwixbuild.utils import Remotefile, run_command, copy_tree
+
+pj = os.path.join
+
+class emsdk(Dependency):
+ dont_skip = True
+ neutral = False
+ name = 'emsdk'
+
+ class Source(ReleaseDownload):
+ archive = Remotefile('emsdk-3.1.24.tar.gz',
+ '1aa5365ccb2147701cc9d1e59a5a49577c1d6aea55da7c450df2d5ffa48b8a58',
+ 'https://codeload.github.com/emscripten-core/emsdk/tar.gz/refs/tags/3.1.24')
+
+ @property
+ def source_dir(self):
+ return self.target.full_name()
+
+
+ class Builder(Builder):
+ @property
+ def install_path(self):
+ return self.build_path
+
+ def _copy_source(self, context):
+ context.try_skip(self.build_path)
+ copy_tree(self.source_path, self.build_path)
+
+ def _install(self, context):
+ context.try_skip(self.build_path)
+ command = "./emsdk install 3.1.24"
+ run_command(command, self.build_path, context)
+
+ def _activate(self, context):
+ context.try_skip(self.build_path)
+ command = "./emsdk activate 3.1.24"
+ run_command(command, self.build_path, context)
+
+
+ def build(self):
+ self.command('copy_source', self._copy_source)
+ self.command('install', self._install)
+ self.command('activate', self._activate)
+
diff --git a/kiwixbuild/dependencies/icu4c.py b/kiwixbuild/dependencies/icu4c.py
index e9457f08..ab2e7662 100644
--- a/kiwixbuild/dependencies/icu4c.py
+++ b/kiwixbuild/dependencies/icu4c.py
@@ -18,7 +18,9 @@ class Source(ReleaseDownload):
"icu4c_custom_data.patch",
"icu4c_noxlocale.patch",
"icu4c_rpath.patch",
- "icu4c_build_config.patch"]
+ "icu4c_build_config.patch",
+ "icu4c_wasm.patch"
+ ]
class Builder(MakeBuilder):
@@ -42,6 +44,6 @@ def configure_option(self):
'native_static' if platformInfo.static else 'native_dyn')
options += " --with-cross-build={} --disable-tools".format(
icu_native_builder.build_path)
- if platformInfo.build == 'android':
+ if platformInfo.build in ('android', 'wasm'):
options += " --with-data-packaging=archive"
return options
diff --git a/kiwixbuild/dependencies/libzim.py b/kiwixbuild/dependencies/libzim.py
index 55eb075b..6f3de2a2 100644
--- a/kiwixbuild/dependencies/libzim.py
+++ b/kiwixbuild/dependencies/libzim.py
@@ -19,7 +19,7 @@ class Builder(MesonBuilder):
@classmethod
def get_dependencies(cls, platformInfo, allDeps):
deps = ['lzma', 'zstd', 'xapian-core', 'icu4c']
- if platformInfo.build != 'flatpak':
+ if platformInfo.name not in ('flatpak', 'wasm'):
deps.append('zim-testing-suite')
return deps
@@ -37,7 +37,9 @@ def configure_option(self):
if platformInfo.name == "flatpak":
config_options.append("--wrap-mode=nodownload")
config_options.append("-Dtest_data_dir=none")
- else:
+ if platformInfo.name == "wasm":
+ config_options.append("-Dexamples=false")
+ if platformInfo.name not in ("flatpak", "wasm"):
zim_testing_suite = get_target_step('zim-testing-suite', 'source')
config_options.append('-Dtest_data_dir={}'.format(zim_testing_suite.source_path))
return " ".join(config_options)
diff --git a/kiwixbuild/dependencies/lzma.py b/kiwixbuild/dependencies/lzma.py
index e26d5c98..bcfb4f7e 100644
--- a/kiwixbuild/dependencies/lzma.py
+++ b/kiwixbuild/dependencies/lzma.py
@@ -9,11 +9,20 @@ class lzma(Dependency):
name = 'lzma'
class Source(ReleaseDownload):
- archive = Remotefile('xz-5.2.4.tar.gz',
- 'b512f3b726d3b37b6dc4c8570e137b9311e7552e8ccbab4d39d47ce5f4177145'
+ archive = Remotefile('xz-5.2.6.tar.gz',
+ 'a2105abee17bcd2ebd15ced31b4f5eda6e17efd6b10f921a01cda4a44c91b3a0',
+ 'https://altushost-swe.dl.sourceforge.net/project/lzmautils/xz-5.2.6.tar.gz'
)
class Builder(MakeBuilder):
@property
def configure_option(self):
- return "--disable-xz --disable-xzdec"
+ return ("--disable-xz "
+ "--disable-xzdec "
+ "--disable-lzmadec "
+ "--disable-lzmainfo "
+ "--disable-lzma-links "
+ "--disable-scripts "
+ "--disable-doc "
+# "--disable-symbol-versions "
+ )
diff --git a/kiwixbuild/dependencies/xapian.py b/kiwixbuild/dependencies/xapian.py
index 149973ba..c0b86ce7 100644
--- a/kiwixbuild/dependencies/xapian.py
+++ b/kiwixbuild/dependencies/xapian.py
@@ -24,7 +24,7 @@ class Builder(MakeBuilder):
@classmethod
def get_dependencies(cls, platformInfo, allDeps):
deps = ['zlib', 'lzma']
- if (platformInfo.build == 'win32'
+ if (platformInfo.build in ('win32', 'wasm')
or neutralEnv('distname') == 'Darwin'):
return deps
return deps + ['uuid']
diff --git a/kiwixbuild/patches/icu4c_wasm.patch b/kiwixbuild/patches/icu4c_wasm.patch
new file mode 100644
index 00000000..af09f486
--- /dev/null
+++ b/kiwixbuild/patches/icu4c_wasm.patch
@@ -0,0 +1,3235 @@
+Seulement dans icu4c-58.2: .patch_ok
+diff '--color=auto' -ur icu4c-58.2/source/config/mh-unknown icu4c-58.2.wasm/source/config/mh-unknown
+--- icu4c-58.2/source/config/mh-unknown 2018-06-11 12:53:36.000000000 +0200
++++ icu4c-58.2.wasm/source/config/mh-unknown 2022-11-07 14:55:26.624194855 +0100
+@@ -1,29 +1,87 @@
+ ## -*-makefile-*-
+ ## Copyright (C) 2016 and later: Unicode, Inc. and others.
+ ## License & terms of use: http://www.unicode.org/copyright.html
+-## Copyright (c) 2003, International Business Machines Corporation and
++## Linux-specific setup
++## Copyright (c) 1999-2013, International Business Machines Corporation and
+ ## others. All Rights Reserved.
+-##
+
+-# Note, this is not a real mh- file. You got here because configure
+-# (specifically, aclocal.m4) could not determine a suitable mh- file.
+-#
+-# Perhaps your platform wasn't detected- try changing aclocal.m4 and
+-# re-running autoconf.
+-#
+-# If your platform is truly new/different:
+-# As a start, try copying mh-linux (which is fairly generic) over this
+-# file, and re-run config.status.
+-
+-%.$(STATIC_O) %.o %.$(STATIC_O) %.o ../data/%.o %.d %.d %.$(SO).$(SO_TARGET_VERSION_MAJOR) %.$(SO):
+- @echo
+- @echo
+- @echo "*** ERROR - configure could not detect your platform"
+- @echo "*** see the readme.html"
+- @echo "*** or, try copying icu/source/config/mh-linux to mh-unknown"
+- @echo "*** and editing it."
+- @echo
+- @echo
+- exit 1
++## Commands to generate dependency files
++GEN_DEPS.c= $(CC) -E -MM $(DEFS) $(CPPFLAGS)
++GEN_DEPS.cc= $(CXX) -E -MM $(DEFS) $(CPPFLAGS) $(CXXFLAGS)
+
++## Flags for position independent code
++SHAREDLIBCFLAGS = -fPIC
++SHAREDLIBCXXFLAGS = -fPIC
++SHAREDLIBCPPFLAGS = -DPIC
++
++## Additional flags when building libraries and with threads
++THREADSCPPFLAGS = -D_REENTRANT
++LIBCPPFLAGS =
++
++## Compiler switch to embed a runtime search path
++LD_RPATH= -Wl,-zorigin,-rpath,'$$'ORIGIN
++LD_RPATH_PRE = -Wl,-rpath,
++
++## These are the library specific LDFLAGS
++LDFLAGSICUDT=-nodefaultlibs -nostdlib
++
++## Compiler switch to embed a library name
++# The initial tab in the next line is to prevent icu-config from reading it.
++ LD_SONAME = -Wl,-soname -Wl,$(notdir $(MIDDLE_SO_TARGET))
++#SH# # We can't depend on MIDDLE_SO_TARGET being set.
++#SH# LD_SONAME=
++
++## Shared library options
++LD_SOOPTIONS= -Wl,-Bsymbolic
++
++## Shared object suffix
++SO = so
++## Non-shared intermediate object suffix
++STATIC_O = ao
++
++## Compilation rules
++%.$(STATIC_O): $(srcdir)/%.c
++ $(call SILENT_COMPILE,$(strip $(COMPILE.c) $(STATICCPPFLAGS) $(STATICCFLAGS)) -o $@ $<)
++%.o: $(srcdir)/%.c
++ $(call SILENT_COMPILE,$(strip $(COMPILE.c) $(DYNAMICCPPFLAGS) $(DYNAMICCFLAGS)) -o $@ $<)
++
++%.$(STATIC_O): $(srcdir)/%.cpp
++ $(call SILENT_COMPILE,$(strip $(COMPILE.cc) $(STATICCPPFLAGS) $(STATICCXXFLAGS)) -o $@ $<)
++%.o: $(srcdir)/%.cpp
++ $(call SILENT_COMPILE,$(strip $(COMPILE.cc) $(DYNAMICCPPFLAGS) $(DYNAMICCXXFLAGS)) -o $@ $<)
++
++
++## Dependency rules
++%.d: $(srcdir)/%.c
++ $(call ICU_MSG,(deps)) $<
++ @$(SHELL) -ec '$(GEN_DEPS.c) $< \
++ | sed '\''s%\($*\)\.o[ :]*%\1.o $@ : %g'\'' > $@; \
++ [ -s $@ ] || rm -f $@'
++
++%.d: $(srcdir)/%.cpp
++ $(call ICU_MSG,(deps)) $<
++ @$(SHELL) -ec '$(GEN_DEPS.cc) $< \
++ | sed '\''s%\($*\)\.o[ :]*%\1.o $@ : %g'\'' > $@; \
++ [ -s $@ ] || rm -f $@'
++
++## Versioned libraries rules
++
++%.$(SO).$(SO_TARGET_VERSION_MAJOR): %.$(SO).$(SO_TARGET_VERSION)
++ $(RM) $@ && ln -s ${.
++# along with this program; if not, see .
+ #
+ # As a special exception to the GNU General Public License, if you
+ # distribute this file as part of a program that contains a
+@@ -25,7 +27,7 @@
+ # of the GNU General Public License, version 3 ("GPLv3").
+
+
+-# Please send patches with a ChangeLog entry to config-patches@gnu.org.
++# Please send patches to .
+ #
+ # Configuration subroutine to validate and canonicalize a configuration type.
+ # Supply the specified configuration type as an argument.
+@@ -33,7 +35,7 @@
+ # Otherwise, we print the canonical config type on stdout and succeed.
+
+ # You can get the latest version of this script from:
+-# http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.sub;hb=HEAD
++# https://git.savannah.gnu.org/cgit/config.git/plain/config.sub
+
+ # This file is supposed to be the same for all GNU packages
+ # and recognize all the CPU types, system types and aliases
+@@ -50,15 +52,21 @@
+ # CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM
+ # It is wrong to echo any other type of specification.
+
++# The "shellcheck disable" line above the timestamp inhibits complaints
++# about features and limitations of the classic Bourne shell that were
++# superseded or lifted in POSIX. However, this script identifies a wide
++# variety of pre-POSIX systems that do not have POSIX shells at all, and
++# even some reasonably current systems (Solaris 10 as case-in-point) still
++# have a pre-POSIX /bin/sh.
++
+ me=`echo "$0" | sed -e 's,.*/,,'`
+
+ usage="\
+-Usage: $0 [OPTION] CPU-MFR-OPSYS
+- $0 [OPTION] ALIAS
++Usage: $0 [OPTION] CPU-MFR-OPSYS or ALIAS
+
+ Canonicalize a configuration name.
+
+-Operation modes:
++Options:
+ -h, --help print this help, then exit
+ -t, --time-stamp print date of last modification, then exit
+ -v, --version print version number, then exit
+@@ -68,7 +76,7 @@
+ version="\
+ GNU config.sub ($timestamp)
+
+-Copyright 1992-2013 Free Software Foundation, Inc.
++Copyright 1992-2021 Free Software Foundation, Inc.
+
+ This is free software; see the source for copying conditions. There is NO
+ warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE."
+@@ -90,12 +98,12 @@
+ - ) # Use stdin as input.
+ break ;;
+ -* )
+- echo "$me: invalid option $1$help"
++ echo "$me: invalid option $1$help" >&2
+ exit 1 ;;
+
+ *local*)
+ # First pass through any local machine types.
+- echo $1
++ echo "$1"
+ exit ;;
+
+ * )
+@@ -111,1211 +119,1181 @@
+ exit 1;;
+ esac
+
+-# Separate what the user gave into CPU-COMPANY and OS or KERNEL-OS (if any).
+-# Here we must recognize all the valid KERNEL-OS combinations.
+-maybe_os=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\2/'`
+-case $maybe_os in
+- nto-qnx* | linux-gnu* | linux-android* | linux-dietlibc | linux-newlib* | \
+- linux-musl* | linux-uclibc* | uclinux-uclibc* | uclinux-gnu* | kfreebsd*-gnu* | \
+- knetbsd*-gnu* | netbsd*-gnu* | \
+- kopensolaris*-gnu* | \
+- storm-chaos* | os2-emx* | rtmk-nova*)
+- os=-$maybe_os
+- basic_machine=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'`
+- ;;
+- android-linux)
+- os=-linux-android
+- basic_machine=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'`-unknown
+- ;;
+- *)
+- basic_machine=`echo $1 | sed 's/-[^-]*$//'`
+- if [ $basic_machine != $1 ]
+- then os=`echo $1 | sed 's/.*-/-/'`
+- else os=; fi
+- ;;
+-esac
+-
+-### Let's recognize common machines as not being operating systems so
+-### that things like config.sub decstation-3100 work. We also
+-### recognize some manufacturers as not being operating systems, so we
+-### can provide default operating systems below.
+-case $os in
+- -sun*os*)
+- # Prevent following clause from handling this invalid input.
+- ;;
+- -dec* | -mips* | -sequent* | -encore* | -pc532* | -sgi* | -sony* | \
+- -att* | -7300* | -3300* | -delta* | -motorola* | -sun[234]* | \
+- -unicom* | -ibm* | -next | -hp | -isi* | -apollo | -altos* | \
+- -convergent* | -ncr* | -news | -32* | -3600* | -3100* | -hitachi* |\
+- -c[123]* | -convex* | -sun | -crds | -omron* | -dg | -ultra | -tti* | \
+- -harris | -dolphin | -highlevel | -gould | -cbm | -ns | -masscomp | \
+- -apple | -axis | -knuth | -cray | -microblaze*)
+- os=
+- basic_machine=$1
+- ;;
+- -bluegene*)
+- os=-cnk
+- ;;
+- -sim | -cisco | -oki | -wec | -winbond)
+- os=
+- basic_machine=$1
+- ;;
+- -scout)
+- ;;
+- -wrs)
+- os=-vxworks
+- basic_machine=$1
+- ;;
+- -chorusos*)
+- os=-chorusos
+- basic_machine=$1
+- ;;
+- -chorusrdb)
+- os=-chorusrdb
+- basic_machine=$1
+- ;;
+- -hiux*)
+- os=-hiuxwe2
+- ;;
+- -sco6)
+- os=-sco5v6
+- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+- ;;
+- -sco5)
+- os=-sco3.2v5
+- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+- ;;
+- -sco4)
+- os=-sco3.2v4
+- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+- ;;
+- -sco3.2.[4-9]*)
+- os=`echo $os | sed -e 's/sco3.2./sco3.2v/'`
+- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+- ;;
+- -sco3.2v[4-9]*)
+- # Don't forget version if it is 3.2v4 or newer.
+- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+- ;;
+- -sco5v6*)
+- # Don't forget version if it is 3.2v4 or newer.
+- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+- ;;
+- -sco*)
+- os=-sco3.2v2
+- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+- ;;
+- -udk*)
+- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+- ;;
+- -isc)
+- os=-isc2.2
+- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+- ;;
+- -clix*)
+- basic_machine=clipper-intergraph
+- ;;
+- -isc*)
+- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+- ;;
+- -lynx*178)
+- os=-lynxos178
+- ;;
+- -lynx*5)
+- os=-lynxos5
+- ;;
+- -lynx*)
+- os=-lynxos
++# Split fields of configuration type
++# shellcheck disable=SC2162
++saved_IFS=$IFS
++IFS="-" read field1 field2 field3 field4 <&2
++ exit 1
+ ;;
+- -ptx*)
+- basic_machine=`echo $1 | sed -e 's/86-.*/86-sequent/'`
++ *-*-*-*)
++ basic_machine=$field1-$field2
++ basic_os=$field3-$field4
+ ;;
+- -windowsnt*)
+- os=`echo $os | sed -e 's/windowsnt/winnt/'`
++ *-*-*)
++ # Ambiguous whether COMPANY is present, or skipped and KERNEL-OS is two
++ # parts
++ maybe_os=$field2-$field3
++ case $maybe_os in
++ nto-qnx* | linux-* | uclinux-uclibc* \
++ | uclinux-gnu* | kfreebsd*-gnu* | knetbsd*-gnu* | netbsd*-gnu* \
++ | netbsd*-eabi* | kopensolaris*-gnu* | cloudabi*-eabi* \
++ | storm-chaos* | os2-emx* | rtmk-nova*)
++ basic_machine=$field1
++ basic_os=$maybe_os
++ ;;
++ android-linux)
++ basic_machine=$field1-unknown
++ basic_os=linux-android
++ ;;
++ *)
++ basic_machine=$field1-$field2
++ basic_os=$field3
++ ;;
++ esac
+ ;;
+- -psos*)
+- os=-psos
++ *-*)
++ # A lone config we happen to match not fitting any pattern
++ case $field1-$field2 in
++ decstation-3100)
++ basic_machine=mips-dec
++ basic_os=
++ ;;
++ *-*)
++ # Second component is usually, but not always the OS
++ case $field2 in
++ # Prevent following clause from handling this valid os
++ sun*os*)
++ basic_machine=$field1
++ basic_os=$field2
++ ;;
++ zephyr*)
++ basic_machine=$field1-unknown
++ basic_os=$field2
++ ;;
++ # Manufacturers
++ dec* | mips* | sequent* | encore* | pc533* | sgi* | sony* \
++ | att* | 7300* | 3300* | delta* | motorola* | sun[234]* \
++ | unicom* | ibm* | next | hp | isi* | apollo | altos* \
++ | convergent* | ncr* | news | 32* | 3600* | 3100* \
++ | hitachi* | c[123]* | convex* | sun | crds | omron* | dg \
++ | ultra | tti* | harris | dolphin | highlevel | gould \
++ | cbm | ns | masscomp | apple | axis | knuth | cray \
++ | microblaze* | sim | cisco \
++ | oki | wec | wrs | winbond)
++ basic_machine=$field1-$field2
++ basic_os=
++ ;;
++ *)
++ basic_machine=$field1
++ basic_os=$field2
++ ;;
++ esac
++ ;;
++ esac
+ ;;
+- -mint | -mint[0-9]*)
+- basic_machine=m68k-atari
+- os=-mint
++ *)
++ # Convert single-component short-hands not valid as part of
++ # multi-component configurations.
++ case $field1 in
++ 386bsd)
++ basic_machine=i386-pc
++ basic_os=bsd
++ ;;
++ a29khif)
++ basic_machine=a29k-amd
++ basic_os=udi
++ ;;
++ adobe68k)
++ basic_machine=m68010-adobe
++ basic_os=scout
++ ;;
++ alliant)
++ basic_machine=fx80-alliant
++ basic_os=
++ ;;
++ altos | altos3068)
++ basic_machine=m68k-altos
++ basic_os=
++ ;;
++ am29k)
++ basic_machine=a29k-none
++ basic_os=bsd
++ ;;
++ amdahl)
++ basic_machine=580-amdahl
++ basic_os=sysv
++ ;;
++ amiga)
++ basic_machine=m68k-unknown
++ basic_os=
++ ;;
++ amigaos | amigados)
++ basic_machine=m68k-unknown
++ basic_os=amigaos
++ ;;
++ amigaunix | amix)
++ basic_machine=m68k-unknown
++ basic_os=sysv4
++ ;;
++ apollo68)
++ basic_machine=m68k-apollo
++ basic_os=sysv
++ ;;
++ apollo68bsd)
++ basic_machine=m68k-apollo
++ basic_os=bsd
++ ;;
++ aros)
++ basic_machine=i386-pc
++ basic_os=aros
++ ;;
++ aux)
++ basic_machine=m68k-apple
++ basic_os=aux
++ ;;
++ balance)
++ basic_machine=ns32k-sequent
++ basic_os=dynix
++ ;;
++ blackfin)
++ basic_machine=bfin-unknown
++ basic_os=linux
++ ;;
++ cegcc)
++ basic_machine=arm-unknown
++ basic_os=cegcc
++ ;;
++ convex-c1)
++ basic_machine=c1-convex
++ basic_os=bsd
++ ;;
++ convex-c2)
++ basic_machine=c2-convex
++ basic_os=bsd
++ ;;
++ convex-c32)
++ basic_machine=c32-convex
++ basic_os=bsd
++ ;;
++ convex-c34)
++ basic_machine=c34-convex
++ basic_os=bsd
++ ;;
++ convex-c38)
++ basic_machine=c38-convex
++ basic_os=bsd
++ ;;
++ cray)
++ basic_machine=j90-cray
++ basic_os=unicos
++ ;;
++ crds | unos)
++ basic_machine=m68k-crds
++ basic_os=
++ ;;
++ da30)
++ basic_machine=m68k-da30
++ basic_os=
++ ;;
++ decstation | pmax | pmin | dec3100 | decstatn)
++ basic_machine=mips-dec
++ basic_os=
++ ;;
++ delta88)
++ basic_machine=m88k-motorola
++ basic_os=sysv3
++ ;;
++ dicos)
++ basic_machine=i686-pc
++ basic_os=dicos
++ ;;
++ djgpp)
++ basic_machine=i586-pc
++ basic_os=msdosdjgpp
++ ;;
++ ebmon29k)
++ basic_machine=a29k-amd
++ basic_os=ebmon
++ ;;
++ es1800 | OSE68k | ose68k | ose | OSE)
++ basic_machine=m68k-ericsson
++ basic_os=ose
++ ;;
++ gmicro)
++ basic_machine=tron-gmicro
++ basic_os=sysv
++ ;;
++ go32)
++ basic_machine=i386-pc
++ basic_os=go32
++ ;;
++ h8300hms)
++ basic_machine=h8300-hitachi
++ basic_os=hms
++ ;;
++ h8300xray)
++ basic_machine=h8300-hitachi
++ basic_os=xray
++ ;;
++ h8500hms)
++ basic_machine=h8500-hitachi
++ basic_os=hms
++ ;;
++ harris)
++ basic_machine=m88k-harris
++ basic_os=sysv3
++ ;;
++ hp300 | hp300hpux)
++ basic_machine=m68k-hp
++ basic_os=hpux
++ ;;
++ hp300bsd)
++ basic_machine=m68k-hp
++ basic_os=bsd
++ ;;
++ hppaosf)
++ basic_machine=hppa1.1-hp
++ basic_os=osf
++ ;;
++ hppro)
++ basic_machine=hppa1.1-hp
++ basic_os=proelf
++ ;;
++ i386mach)
++ basic_machine=i386-mach
++ basic_os=mach
++ ;;
++ isi68 | isi)
++ basic_machine=m68k-isi
++ basic_os=sysv
++ ;;
++ m68knommu)
++ basic_machine=m68k-unknown
++ basic_os=linux
++ ;;
++ magnum | m3230)
++ basic_machine=mips-mips
++ basic_os=sysv
++ ;;
++ merlin)
++ basic_machine=ns32k-utek
++ basic_os=sysv
++ ;;
++ mingw64)
++ basic_machine=x86_64-pc
++ basic_os=mingw64
++ ;;
++ mingw32)
++ basic_machine=i686-pc
++ basic_os=mingw32
++ ;;
++ mingw32ce)
++ basic_machine=arm-unknown
++ basic_os=mingw32ce
++ ;;
++ monitor)
++ basic_machine=m68k-rom68k
++ basic_os=coff
++ ;;
++ morphos)
++ basic_machine=powerpc-unknown
++ basic_os=morphos
++ ;;
++ moxiebox)
++ basic_machine=moxie-unknown
++ basic_os=moxiebox
++ ;;
++ msdos)
++ basic_machine=i386-pc
++ basic_os=msdos
++ ;;
++ msys)
++ basic_machine=i686-pc
++ basic_os=msys
++ ;;
++ mvs)
++ basic_machine=i370-ibm
++ basic_os=mvs
++ ;;
++ nacl)
++ basic_machine=le32-unknown
++ basic_os=nacl
++ ;;
++ ncr3000)
++ basic_machine=i486-ncr
++ basic_os=sysv4
++ ;;
++ netbsd386)
++ basic_machine=i386-pc
++ basic_os=netbsd
++ ;;
++ netwinder)
++ basic_machine=armv4l-rebel
++ basic_os=linux
++ ;;
++ news | news700 | news800 | news900)
++ basic_machine=m68k-sony
++ basic_os=newsos
++ ;;
++ news1000)
++ basic_machine=m68030-sony
++ basic_os=newsos
++ ;;
++ necv70)
++ basic_machine=v70-nec
++ basic_os=sysv
++ ;;
++ nh3000)
++ basic_machine=m68k-harris
++ basic_os=cxux
++ ;;
++ nh[45]000)
++ basic_machine=m88k-harris
++ basic_os=cxux
++ ;;
++ nindy960)
++ basic_machine=i960-intel
++ basic_os=nindy
++ ;;
++ mon960)
++ basic_machine=i960-intel
++ basic_os=mon960
++ ;;
++ nonstopux)
++ basic_machine=mips-compaq
++ basic_os=nonstopux
++ ;;
++ os400)
++ basic_machine=powerpc-ibm
++ basic_os=os400
++ ;;
++ OSE68000 | ose68000)
++ basic_machine=m68000-ericsson
++ basic_os=ose
++ ;;
++ os68k)
++ basic_machine=m68k-none
++ basic_os=os68k
++ ;;
++ paragon)
++ basic_machine=i860-intel
++ basic_os=osf
++ ;;
++ parisc)
++ basic_machine=hppa-unknown
++ basic_os=linux
++ ;;
++ psp)
++ basic_machine=mipsallegrexel-sony
++ basic_os=psp
++ ;;
++ pw32)
++ basic_machine=i586-unknown
++ basic_os=pw32
++ ;;
++ rdos | rdos64)
++ basic_machine=x86_64-pc
++ basic_os=rdos
++ ;;
++ rdos32)
++ basic_machine=i386-pc
++ basic_os=rdos
++ ;;
++ rom68k)
++ basic_machine=m68k-rom68k
++ basic_os=coff
++ ;;
++ sa29200)
++ basic_machine=a29k-amd
++ basic_os=udi
++ ;;
++ sei)
++ basic_machine=mips-sei
++ basic_os=seiux
++ ;;
++ sequent)
++ basic_machine=i386-sequent
++ basic_os=
++ ;;
++ sps7)
++ basic_machine=m68k-bull
++ basic_os=sysv2
++ ;;
++ st2000)
++ basic_machine=m68k-tandem
++ basic_os=
++ ;;
++ stratus)
++ basic_machine=i860-stratus
++ basic_os=sysv4
++ ;;
++ sun2)
++ basic_machine=m68000-sun
++ basic_os=
++ ;;
++ sun2os3)
++ basic_machine=m68000-sun
++ basic_os=sunos3
++ ;;
++ sun2os4)
++ basic_machine=m68000-sun
++ basic_os=sunos4
++ ;;
++ sun3)
++ basic_machine=m68k-sun
++ basic_os=
++ ;;
++ sun3os3)
++ basic_machine=m68k-sun
++ basic_os=sunos3
++ ;;
++ sun3os4)
++ basic_machine=m68k-sun
++ basic_os=sunos4
++ ;;
++ sun4)
++ basic_machine=sparc-sun
++ basic_os=
++ ;;
++ sun4os3)
++ basic_machine=sparc-sun
++ basic_os=sunos3
++ ;;
++ sun4os4)
++ basic_machine=sparc-sun
++ basic_os=sunos4
++ ;;
++ sun4sol2)
++ basic_machine=sparc-sun
++ basic_os=solaris2
++ ;;
++ sun386 | sun386i | roadrunner)
++ basic_machine=i386-sun
++ basic_os=
++ ;;
++ sv1)
++ basic_machine=sv1-cray
++ basic_os=unicos
++ ;;
++ symmetry)
++ basic_machine=i386-sequent
++ basic_os=dynix
++ ;;
++ t3e)
++ basic_machine=alphaev5-cray
++ basic_os=unicos
++ ;;
++ t90)
++ basic_machine=t90-cray
++ basic_os=unicos
++ ;;
++ toad1)
++ basic_machine=pdp10-xkl
++ basic_os=tops20
++ ;;
++ tpf)
++ basic_machine=s390x-ibm
++ basic_os=tpf
++ ;;
++ udi29k)
++ basic_machine=a29k-amd
++ basic_os=udi
++ ;;
++ ultra3)
++ basic_machine=a29k-nyu
++ basic_os=sym1
++ ;;
++ v810 | necv810)
++ basic_machine=v810-nec
++ basic_os=none
++ ;;
++ vaxv)
++ basic_machine=vax-dec
++ basic_os=sysv
++ ;;
++ vms)
++ basic_machine=vax-dec
++ basic_os=vms
++ ;;
++ vsta)
++ basic_machine=i386-pc
++ basic_os=vsta
++ ;;
++ vxworks960)
++ basic_machine=i960-wrs
++ basic_os=vxworks
++ ;;
++ vxworks68)
++ basic_machine=m68k-wrs
++ basic_os=vxworks
++ ;;
++ vxworks29k)
++ basic_machine=a29k-wrs
++ basic_os=vxworks
++ ;;
++ xbox)
++ basic_machine=i686-pc
++ basic_os=mingw32
++ ;;
++ ymp)
++ basic_machine=ymp-cray
++ basic_os=unicos
++ ;;
++ *)
++ basic_machine=$1
++ basic_os=
++ ;;
++ esac
+ ;;
+ esac
+
+-# Decode aliases for certain CPU-COMPANY combinations.
++# Decode 1-component or ad-hoc basic machines
+ case $basic_machine in
+- # Recognize the basic CPU types without company name.
+- # Some are omitted here because they have special meanings below.
+- 1750a | 580 \
+- | a29k \
+- | aarch64 | aarch64_be \
+- | alpha | alphaev[4-8] | alphaev56 | alphaev6[78] | alphapca5[67] \
+- | alpha64 | alpha64ev[4-8] | alpha64ev56 | alpha64ev6[78] | alpha64pca5[67] \
+- | am33_2.0 \
+- | arc | arceb \
+- | arm | arm[bl]e | arme[lb] | armv[2-8] | armv[3-8][lb] | armv7[arm] \
+- | avr | avr32 \
+- | be32 | be64 \
+- | bfin \
+- | c4x | c8051 | clipper \
+- | d10v | d30v | dlx | dsp16xx \
+- | epiphany \
+- | fido | fr30 | frv \
+- | h8300 | h8500 | hppa | hppa1.[01] | hppa2.0 | hppa2.0[nw] | hppa64 \
+- | hexagon \
+- | i370 | i860 | i960 | ia64 \
+- | ip2k | iq2000 \
+- | k1om \
+- | le32 | le64 \
+- | lm32 \
+- | m32c | m32r | m32rle | m68000 | m68k | m88k \
+- | maxq | mb | microblaze | microblazeel | mcore | mep | metag \
+- | mips | mipsbe | mipseb | mipsel | mipsle \
+- | mips16 \
+- | mips64 | mips64el \
+- | mips64octeon | mips64octeonel \
+- | mips64orion | mips64orionel \
+- | mips64r5900 | mips64r5900el \
+- | mips64vr | mips64vrel \
+- | mips64vr4100 | mips64vr4100el \
+- | mips64vr4300 | mips64vr4300el \
+- | mips64vr5000 | mips64vr5000el \
+- | mips64vr5900 | mips64vr5900el \
+- | mipsisa32 | mipsisa32el \
+- | mipsisa32r2 | mipsisa32r2el \
+- | mipsisa64 | mipsisa64el \
+- | mipsisa64r2 | mipsisa64r2el \
+- | mipsisa64sb1 | mipsisa64sb1el \
+- | mipsisa64sr71k | mipsisa64sr71kel \
+- | mipsr5900 | mipsr5900el \
+- | mipstx39 | mipstx39el \
+- | mn10200 | mn10300 \
+- | moxie \
+- | mt \
+- | msp430 \
+- | nds32 | nds32le | nds32be \
+- | nios | nios2 | nios2eb | nios2el \
+- | ns16k | ns32k \
+- | open8 \
+- | or1k | or32 \
+- | pdp10 | pdp11 | pj | pjl \
+- | powerpc | powerpc64 | powerpc64le | powerpcle \
+- | pyramid \
+- | rl78 | rx \
+- | score \
+- | sh | sh[1234] | sh[24]a | sh[24]aeb | sh[23]e | sh[34]eb | sheb | shbe | shle | sh[1234]le | sh3ele \
+- | sh64 | sh64le \
+- | sparc | sparc64 | sparc64b | sparc64v | sparc86x | sparclet | sparclite \
+- | sparcv8 | sparcv9 | sparcv9b | sparcv9v \
+- | spu \
+- | tahoe | tic4x | tic54x | tic55x | tic6x | tic80 | tron \
+- | ubicom32 \
+- | v850 | v850e | v850e1 | v850e2 | v850es | v850e2v3 \
+- | we32k \
+- | x86 | xc16x | xstormy16 | xtensa \
+- | z8k | z80)
+- basic_machine=$basic_machine-unknown
+- ;;
+- c54x)
+- basic_machine=tic54x-unknown
+- ;;
+- c55x)
+- basic_machine=tic55x-unknown
+- ;;
+- c6x)
+- basic_machine=tic6x-unknown
+- ;;
+- m6811 | m68hc11 | m6812 | m68hc12 | m68hcs12x | nvptx | picochip)
+- basic_machine=$basic_machine-unknown
+- os=-none
+- ;;
+- m88110 | m680[12346]0 | m683?2 | m68360 | m5200 | v70 | w65 | z8k)
+- ;;
+- ms1)
+- basic_machine=mt-unknown
+- ;;
+-
+- strongarm | thumb | xscale)
+- basic_machine=arm-unknown
+- ;;
+- xgate)
+- basic_machine=$basic_machine-unknown
+- os=-none
++ # Here we handle the default manufacturer of certain CPU types. It is in
++ # some cases the only manufacturer, in others, it is the most popular.
++ w89k)
++ cpu=hppa1.1
++ vendor=winbond
+ ;;
+- xscaleeb)
+- basic_machine=armeb-unknown
++ op50n)
++ cpu=hppa1.1
++ vendor=oki
+ ;;
+-
+- xscaleel)
+- basic_machine=armel-unknown
++ op60c)
++ cpu=hppa1.1
++ vendor=oki
+ ;;
+-
+- # We use `pc' rather than `unknown'
+- # because (1) that's what they normally are, and
+- # (2) the word "unknown" tends to confuse beginning users.
+- i*86 | x86_64)
+- basic_machine=$basic_machine-pc
+- ;;
+- # Object if more than one company name word.
+- *-*-*)
+- echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2
+- exit 1
++ ibm*)
++ cpu=i370
++ vendor=ibm
+ ;;
+- # Recognize the basic CPU types with company name.
+- 580-* \
+- | a29k-* \
+- | aarch64-* | aarch64_be-* \
+- | alpha-* | alphaev[4-8]-* | alphaev56-* | alphaev6[78]-* \
+- | alpha64-* | alpha64ev[4-8]-* | alpha64ev56-* | alpha64ev6[78]-* \
+- | alphapca5[67]-* | alpha64pca5[67]-* | arc-* | arceb-* \
+- | arm-* | armbe-* | armle-* | armeb-* | armv*-* \
+- | avr-* | avr32-* \
+- | be32-* | be64-* \
+- | bfin-* | bs2000-* \
+- | c[123]* | c30-* | [cjt]90-* | c4x-* \
+- | c8051-* | clipper-* | craynv-* | cydra-* \
+- | d10v-* | d30v-* | dlx-* \
+- | elxsi-* \
+- | f30[01]-* | f700-* | fido-* | fr30-* | frv-* | fx80-* \
+- | h8300-* | h8500-* \
+- | hppa-* | hppa1.[01]-* | hppa2.0-* | hppa2.0[nw]-* | hppa64-* \
+- | hexagon-* \
+- | i*86-* | i860-* | i960-* | ia64-* \
+- | ip2k-* | iq2000-* \
+- | k1om-* \
+- | le32-* | le64-* \
+- | lm32-* \
+- | m32c-* | m32r-* | m32rle-* \
+- | m68000-* | m680[012346]0-* | m68360-* | m683?2-* | m68k-* \
+- | m88110-* | m88k-* | maxq-* | mcore-* | metag-* \
+- | microblaze-* | microblazeel-* \
+- | mips-* | mipsbe-* | mipseb-* | mipsel-* | mipsle-* \
+- | mips16-* \
+- | mips64-* | mips64el-* \
+- | mips64octeon-* | mips64octeonel-* \
+- | mips64orion-* | mips64orionel-* \
+- | mips64r5900-* | mips64r5900el-* \
+- | mips64vr-* | mips64vrel-* \
+- | mips64vr4100-* | mips64vr4100el-* \
+- | mips64vr4300-* | mips64vr4300el-* \
+- | mips64vr5000-* | mips64vr5000el-* \
+- | mips64vr5900-* | mips64vr5900el-* \
+- | mipsisa32-* | mipsisa32el-* \
+- | mipsisa32r2-* | mipsisa32r2el-* \
+- | mipsisa64-* | mipsisa64el-* \
+- | mipsisa64r2-* | mipsisa64r2el-* \
+- | mipsisa64sb1-* | mipsisa64sb1el-* \
+- | mipsisa64sr71k-* | mipsisa64sr71kel-* \
+- | mipsr5900-* | mipsr5900el-* \
+- | mipstx39-* | mipstx39el-* \
+- | mmix-* \
+- | mt-* \
+- | msp430-* \
+- | nds32-* | nds32le-* | nds32be-* \
+- | nios-* | nios2-* | nios2eb-* | nios2el-* \
+- | none-* | np1-* | ns16k-* | ns32k-* \
+- | open8-* \
+- | orion-* \
+- | pdp10-* | pdp11-* | pj-* | pjl-* | pn-* | power-* \
+- | powerpc-* | powerpc64-* | powerpc64le-* | powerpcle-* \
+- | pyramid-* \
+- | rl78-* | romp-* | rs6000-* | rx-* \
+- | sh-* | sh[1234]-* | sh[24]a-* | sh[24]aeb-* | sh[23]e-* | sh[34]eb-* | sheb-* | shbe-* \
+- | shle-* | sh[1234]le-* | sh3ele-* | sh64-* | sh64le-* \
+- | sparc-* | sparc64-* | sparc64b-* | sparc64v-* | sparc86x-* | sparclet-* \
+- | sparclite-* \
+- | sparcv8-* | sparcv9-* | sparcv9b-* | sparcv9v-* | sv1-* | sx?-* \
+- | tahoe-* \
+- | tic30-* | tic4x-* | tic54x-* | tic55x-* | tic6x-* | tic80-* \
+- | tile*-* \
+- | tron-* \
+- | ubicom32-* \
+- | v850-* | v850e-* | v850e1-* | v850es-* | v850e2-* | v850e2v3-* \
+- | vax-* \
+- | we32k-* \
+- | x86-* | x86_64-* | xc16x-* | xps100-* \
+- | xstormy16-* | xtensa*-* \
+- | ymp-* \
+- | z8k-* | z80-*)
+- ;;
+- # Recognize the basic CPU types without company name, with glob match.
+- xtensa*)
+- basic_machine=$basic_machine-unknown
++ orion105)
++ cpu=clipper
++ vendor=highlevel
++ ;;
++ mac | mpw | mac-mpw)
++ cpu=m68k
++ vendor=apple
+ ;;
++ pmac | pmac-mpw)
++ cpu=powerpc
++ vendor=apple
++ ;;
++
+ # Recognize the various machine names and aliases which stand
+ # for a CPU type and a company and sometimes even an OS.
+- 386bsd)
+- basic_machine=i386-unknown
+- os=-bsd
+- ;;
+ 3b1 | 7300 | 7300-att | att-7300 | pc7300 | safari | unixpc)
+- basic_machine=m68000-att
++ cpu=m68000
++ vendor=att
+ ;;
+ 3b*)
+- basic_machine=we32k-att
+- ;;
+- a29khif)
+- basic_machine=a29k-amd
+- os=-udi
+- ;;
+- abacus)
+- basic_machine=abacus-unknown
+- ;;
+- adobe68k)
+- basic_machine=m68010-adobe
+- os=-scout
+- ;;
+- alliant | fx80)
+- basic_machine=fx80-alliant
+- ;;
+- altos | altos3068)
+- basic_machine=m68k-altos
+- ;;
+- am29k)
+- basic_machine=a29k-none
+- os=-bsd
+- ;;
+- amd64)
+- basic_machine=x86_64-pc
+- ;;
+- amd64-*)
+- basic_machine=x86_64-`echo $basic_machine | sed 's/^[^-]*-//'`
+- ;;
+- amdahl)
+- basic_machine=580-amdahl
+- os=-sysv
+- ;;
+- amiga | amiga-*)
+- basic_machine=m68k-unknown
+- ;;
+- amigaos | amigados)
+- basic_machine=m68k-unknown
+- os=-amigaos
+- ;;
+- amigaunix | amix)
+- basic_machine=m68k-unknown
+- os=-sysv4
+- ;;
+- apollo68)
+- basic_machine=m68k-apollo
+- os=-sysv
+- ;;
+- apollo68bsd)
+- basic_machine=m68k-apollo
+- os=-bsd
+- ;;
+- aros)
+- basic_machine=i386-pc
+- os=-aros
+- ;;
+- aux)
+- basic_machine=m68k-apple
+- os=-aux
+- ;;
+- balance)
+- basic_machine=ns32k-sequent
+- os=-dynix
+- ;;
+- blackfin)
+- basic_machine=bfin-unknown
+- os=-linux
+- ;;
+- blackfin-*)
+- basic_machine=bfin-`echo $basic_machine | sed 's/^[^-]*-//'`
+- os=-linux
++ cpu=we32k
++ vendor=att
+ ;;
+ bluegene*)
+- basic_machine=powerpc-ibm
+- os=-cnk
+- ;;
+- c54x-*)
+- basic_machine=tic54x-`echo $basic_machine | sed 's/^[^-]*-//'`
+- ;;
+- c55x-*)
+- basic_machine=tic55x-`echo $basic_machine | sed 's/^[^-]*-//'`
+- ;;
+- c6x-*)
+- basic_machine=tic6x-`echo $basic_machine | sed 's/^[^-]*-//'`
+- ;;
+- c90)
+- basic_machine=c90-cray
+- os=-unicos
+- ;;
+- cegcc)
+- basic_machine=arm-unknown
+- os=-cegcc
+- ;;
+- convex-c1)
+- basic_machine=c1-convex
+- os=-bsd
+- ;;
+- convex-c2)
+- basic_machine=c2-convex
+- os=-bsd
+- ;;
+- convex-c32)
+- basic_machine=c32-convex
+- os=-bsd
+- ;;
+- convex-c34)
+- basic_machine=c34-convex
+- os=-bsd
+- ;;
+- convex-c38)
+- basic_machine=c38-convex
+- os=-bsd
+- ;;
+- cray | j90)
+- basic_machine=j90-cray
+- os=-unicos
+- ;;
+- craynv)
+- basic_machine=craynv-cray
+- os=-unicosmp
+- ;;
+- cr16 | cr16-*)
+- basic_machine=cr16-unknown
+- os=-elf
+- ;;
+- crds | unos)
+- basic_machine=m68k-crds
+- ;;
+- crisv32 | crisv32-* | etraxfs*)
+- basic_machine=crisv32-axis
+- ;;
+- cris | cris-* | etrax*)
+- basic_machine=cris-axis
+- ;;
+- crx)
+- basic_machine=crx-unknown
+- os=-elf
+- ;;
+- da30 | da30-*)
+- basic_machine=m68k-da30
+- ;;
+- decstation | decstation-3100 | pmax | pmax-* | pmin | dec3100 | decstatn)
+- basic_machine=mips-dec
++ cpu=powerpc
++ vendor=ibm
++ basic_os=cnk
+ ;;
+ decsystem10* | dec10*)
+- basic_machine=pdp10-dec
+- os=-tops10
++ cpu=pdp10
++ vendor=dec
++ basic_os=tops10
+ ;;
+ decsystem20* | dec20*)
+- basic_machine=pdp10-dec
+- os=-tops20
++ cpu=pdp10
++ vendor=dec
++ basic_os=tops20
+ ;;
+ delta | 3300 | motorola-3300 | motorola-delta \
+ | 3300-motorola | delta-motorola)
+- basic_machine=m68k-motorola
+- ;;
+- delta88)
+- basic_machine=m88k-motorola
+- os=-sysv3
+- ;;
+- dicos)
+- basic_machine=i686-pc
+- os=-dicos
+- ;;
+- djgpp)
+- basic_machine=i586-pc
+- os=-msdosdjgpp
+- ;;
+- dpx20 | dpx20-*)
+- basic_machine=rs6000-bull
+- os=-bosx
+- ;;
+- dpx2* | dpx2*-bull)
+- basic_machine=m68k-bull
+- os=-sysv3
+- ;;
+- ebmon29k)
+- basic_machine=a29k-amd
+- os=-ebmon
++ cpu=m68k
++ vendor=motorola
+ ;;
+- elxsi)
+- basic_machine=elxsi-elxsi
+- os=-bsd
++ dpx2*)
++ cpu=m68k
++ vendor=bull
++ basic_os=sysv3
+ ;;
+ encore | umax | mmax)
+- basic_machine=ns32k-encore
++ cpu=ns32k
++ vendor=encore
+ ;;
+- es1800 | OSE68k | ose68k | ose | OSE)
+- basic_machine=m68k-ericsson
+- os=-ose
++ elxsi)
++ cpu=elxsi
++ vendor=elxsi
++ basic_os=${basic_os:-bsd}
+ ;;
+ fx2800)
+- basic_machine=i860-alliant
++ cpu=i860
++ vendor=alliant
+ ;;
+ genix)
+- basic_machine=ns32k-ns
+- ;;
+- gmicro)
+- basic_machine=tron-gmicro
+- os=-sysv
+- ;;
+- go32)
+- basic_machine=i386-pc
+- os=-go32
++ cpu=ns32k
++ vendor=ns
+ ;;
+ h3050r* | hiux*)
+- basic_machine=hppa1.1-hitachi
+- os=-hiuxwe2
+- ;;
+- h8300hms)
+- basic_machine=h8300-hitachi
+- os=-hms
+- ;;
+- h8300xray)
+- basic_machine=h8300-hitachi
+- os=-xray
+- ;;
+- h8500hms)
+- basic_machine=h8500-hitachi
+- os=-hms
+- ;;
+- harris)
+- basic_machine=m88k-harris
+- os=-sysv3
+- ;;
+- hp300-*)
+- basic_machine=m68k-hp
+- ;;
+- hp300bsd)
+- basic_machine=m68k-hp
+- os=-bsd
+- ;;
+- hp300hpux)
+- basic_machine=m68k-hp
+- os=-hpux
++ cpu=hppa1.1
++ vendor=hitachi
++ basic_os=hiuxwe2
+ ;;
+ hp3k9[0-9][0-9] | hp9[0-9][0-9])
+- basic_machine=hppa1.0-hp
++ cpu=hppa1.0
++ vendor=hp
+ ;;
+ hp9k2[0-9][0-9] | hp9k31[0-9])
+- basic_machine=m68000-hp
++ cpu=m68000
++ vendor=hp
+ ;;
+ hp9k3[2-9][0-9])
+- basic_machine=m68k-hp
++ cpu=m68k
++ vendor=hp
+ ;;
+ hp9k6[0-9][0-9] | hp6[0-9][0-9])
+- basic_machine=hppa1.0-hp
++ cpu=hppa1.0
++ vendor=hp
+ ;;
+ hp9k7[0-79][0-9] | hp7[0-79][0-9])
+- basic_machine=hppa1.1-hp
++ cpu=hppa1.1
++ vendor=hp
+ ;;
+ hp9k78[0-9] | hp78[0-9])
+ # FIXME: really hppa2.0-hp
+- basic_machine=hppa1.1-hp
++ cpu=hppa1.1
++ vendor=hp
+ ;;
+ hp9k8[67]1 | hp8[67]1 | hp9k80[24] | hp80[24] | hp9k8[78]9 | hp8[78]9 | hp9k893 | hp893)
+ # FIXME: really hppa2.0-hp
+- basic_machine=hppa1.1-hp
++ cpu=hppa1.1
++ vendor=hp
+ ;;
+ hp9k8[0-9][13679] | hp8[0-9][13679])
+- basic_machine=hppa1.1-hp
++ cpu=hppa1.1
++ vendor=hp
+ ;;
+ hp9k8[0-9][0-9] | hp8[0-9][0-9])
+- basic_machine=hppa1.0-hp
+- ;;
+- hppa-next)
+- os=-nextstep3
+- ;;
+- hppaosf)
+- basic_machine=hppa1.1-hp
+- os=-osf
+- ;;
+- hppro)
+- basic_machine=hppa1.1-hp
+- os=-proelf
+- ;;
+- i370-ibm* | ibm*)
+- basic_machine=i370-ibm
++ cpu=hppa1.0
++ vendor=hp
+ ;;
+ i*86v32)
+- basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
+- os=-sysv32
++ cpu=`echo "$1" | sed -e 's/86.*/86/'`
++ vendor=pc
++ basic_os=sysv32
+ ;;
+ i*86v4*)
+- basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
+- os=-sysv4
++ cpu=`echo "$1" | sed -e 's/86.*/86/'`
++ vendor=pc
++ basic_os=sysv4
+ ;;
+ i*86v)
+- basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
+- os=-sysv
++ cpu=`echo "$1" | sed -e 's/86.*/86/'`
++ vendor=pc
++ basic_os=sysv
+ ;;
+ i*86sol2)
+- basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
+- os=-solaris2
+- ;;
+- i386mach)
+- basic_machine=i386-mach
+- os=-mach
+- ;;
+- i386-vsta | vsta)
+- basic_machine=i386-unknown
+- os=-vsta
++ cpu=`echo "$1" | sed -e 's/86.*/86/'`
++ vendor=pc
++ basic_os=solaris2
++ ;;
++ j90 | j90-cray)
++ cpu=j90
++ vendor=cray
++ basic_os=${basic_os:-unicos}
+ ;;
+ iris | iris4d)
+- basic_machine=mips-sgi
+- case $os in
+- -irix*)
++ cpu=mips
++ vendor=sgi
++ case $basic_os in
++ irix*)
+ ;;
+ *)
+- os=-irix4
++ basic_os=irix4
+ ;;
+ esac
+ ;;
+- isi68 | isi)
+- basic_machine=m68k-isi
+- os=-sysv
+- ;;
+- m68knommu)
+- basic_machine=m68k-unknown
+- os=-linux
+- ;;
+- m68knommu-*)
+- basic_machine=m68k-`echo $basic_machine | sed 's/^[^-]*-//'`
+- os=-linux
+- ;;
+- m88k-omron*)
+- basic_machine=m88k-omron
+- ;;
+- magnum | m3230)
+- basic_machine=mips-mips
+- os=-sysv
+- ;;
+- merlin)
+- basic_machine=ns32k-utek
+- os=-sysv
+- ;;
+- microblaze*)
+- basic_machine=microblaze-xilinx
+- ;;
+- mingw64)
+- basic_machine=x86_64-pc
+- os=-mingw64
+- ;;
+- mingw32)
+- basic_machine=i686-pc
+- os=-mingw32
+- ;;
+- mingw32ce)
+- basic_machine=arm-unknown
+- os=-mingw32ce
+- ;;
+ miniframe)
+- basic_machine=m68000-convergent
+- ;;
+- *mint | -mint[0-9]* | *MiNT | *MiNT[0-9]*)
+- basic_machine=m68k-atari
+- os=-mint
+- ;;
+- mips3*-*)
+- basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'`
++ cpu=m68000
++ vendor=convergent
+ ;;
+- mips3*)
+- basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'`-unknown
+- ;;
+- monitor)
+- basic_machine=m68k-rom68k
+- os=-coff
+- ;;
+- morphos)
+- basic_machine=powerpc-unknown
+- os=-morphos
+- ;;
+- msdos)
+- basic_machine=i386-pc
+- os=-msdos
+- ;;
+- ms1-*)
+- basic_machine=`echo $basic_machine | sed -e 's/ms1-/mt-/'`
+- ;;
+- msys)
+- basic_machine=i686-pc
+- os=-msys
+- ;;
+- mvs)
+- basic_machine=i370-ibm
+- os=-mvs
+- ;;
+- nacl)
+- basic_machine=le32-unknown
+- os=-nacl
+- ;;
+- ncr3000)
+- basic_machine=i486-ncr
+- os=-sysv4
+- ;;
+- netbsd386)
+- basic_machine=i386-unknown
+- os=-netbsd
+- ;;
+- netwinder)
+- basic_machine=armv4l-rebel
+- os=-linux
+- ;;
+- news | news700 | news800 | news900)
+- basic_machine=m68k-sony
+- os=-newsos
+- ;;
+- news1000)
+- basic_machine=m68030-sony
+- os=-newsos
++ *mint | mint[0-9]* | *MiNT | *MiNT[0-9]*)
++ cpu=m68k
++ vendor=atari
++ basic_os=mint
+ ;;
+ news-3600 | risc-news)
+- basic_machine=mips-sony
+- os=-newsos
+- ;;
+- necv70)
+- basic_machine=v70-nec
+- os=-sysv
+- ;;
+- next | m*-next )
+- basic_machine=m68k-next
+- case $os in
+- -nextstep* )
++ cpu=mips
++ vendor=sony
++ basic_os=newsos
++ ;;
++ next | m*-next)
++ cpu=m68k
++ vendor=next
++ case $basic_os in
++ openstep*)
++ ;;
++ nextstep*)
+ ;;
+- -ns2*)
+- os=-nextstep2
++ ns2*)
++ basic_os=nextstep2
+ ;;
+ *)
+- os=-nextstep3
++ basic_os=nextstep3
+ ;;
+ esac
+ ;;
+- nh3000)
+- basic_machine=m68k-harris
+- os=-cxux
+- ;;
+- nh[45]000)
+- basic_machine=m88k-harris
+- os=-cxux
+- ;;
+- nindy960)
+- basic_machine=i960-intel
+- os=-nindy
+- ;;
+- mon960)
+- basic_machine=i960-intel
+- os=-mon960
+- ;;
+- nonstopux)
+- basic_machine=mips-compaq
+- os=-nonstopux
+- ;;
+ np1)
+- basic_machine=np1-gould
+- ;;
+- neo-tandem)
+- basic_machine=neo-tandem
+- ;;
+- nse-tandem)
+- basic_machine=nse-tandem
+- ;;
+- nsr-tandem)
+- basic_machine=nsr-tandem
++ cpu=np1
++ vendor=gould
+ ;;
+ op50n-* | op60c-*)
+- basic_machine=hppa1.1-oki
+- os=-proelf
+- ;;
+- openrisc | openrisc-*)
+- basic_machine=or32-unknown
+- ;;
+- os400)
+- basic_machine=powerpc-ibm
+- os=-os400
+- ;;
+- OSE68000 | ose68000)
+- basic_machine=m68000-ericsson
+- os=-ose
+- ;;
+- os68k)
+- basic_machine=m68k-none
+- os=-os68k
++ cpu=hppa1.1
++ vendor=oki
++ basic_os=proelf
+ ;;
+ pa-hitachi)
+- basic_machine=hppa1.1-hitachi
+- os=-hiuxwe2
+- ;;
+- paragon)
+- basic_machine=i860-intel
+- os=-osf
+- ;;
+- parisc)
+- basic_machine=hppa-unknown
+- os=-linux
+- ;;
+- parisc-*)
+- basic_machine=hppa-`echo $basic_machine | sed 's/^[^-]*-//'`
+- os=-linux
++ cpu=hppa1.1
++ vendor=hitachi
++ basic_os=hiuxwe2
+ ;;
+ pbd)
+- basic_machine=sparc-tti
++ cpu=sparc
++ vendor=tti
+ ;;
+ pbb)
+- basic_machine=m68k-tti
++ cpu=m68k
++ vendor=tti
+ ;;
+- pc532 | pc532-*)
+- basic_machine=ns32k-pc532
+- ;;
+- pc98)
+- basic_machine=i386-pc
+- ;;
+- pc98-*)
+- basic_machine=i386-`echo $basic_machine | sed 's/^[^-]*-//'`
+- ;;
+- pentium | p5 | k5 | k6 | nexgen | viac3)
+- basic_machine=i586-pc
+- ;;
+- pentiumpro | p6 | 6x86 | athlon | athlon_*)
+- basic_machine=i686-pc
+- ;;
+- pentiumii | pentium2 | pentiumiii | pentium3)
+- basic_machine=i686-pc
+- ;;
+- pentium4)
+- basic_machine=i786-pc
+- ;;
+- pentium-* | p5-* | k5-* | k6-* | nexgen-* | viac3-*)
+- basic_machine=i586-`echo $basic_machine | sed 's/^[^-]*-//'`
+- ;;
+- pentiumpro-* | p6-* | 6x86-* | athlon-*)
+- basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'`
+- ;;
+- pentiumii-* | pentium2-* | pentiumiii-* | pentium3-*)
+- basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'`
+- ;;
+- pentium4-*)
+- basic_machine=i786-`echo $basic_machine | sed 's/^[^-]*-//'`
++ pc532)
++ cpu=ns32k
++ vendor=pc532
+ ;;
+ pn)
+- basic_machine=pn-gould
+- ;;
+- power) basic_machine=power-ibm
++ cpu=pn
++ vendor=gould
+ ;;
+- ppc | ppcbe) basic_machine=powerpc-unknown
+- ;;
+- ppc-* | ppcbe-*)
+- basic_machine=powerpc-`echo $basic_machine | sed 's/^[^-]*-//'`
+- ;;
+- ppcle | powerpclittle | ppc-le | powerpc-little)
+- basic_machine=powerpcle-unknown
+- ;;
+- ppcle-* | powerpclittle-*)
+- basic_machine=powerpcle-`echo $basic_machine | sed 's/^[^-]*-//'`
+- ;;
+- ppc64) basic_machine=powerpc64-unknown
+- ;;
+- ppc64-*) basic_machine=powerpc64-`echo $basic_machine | sed 's/^[^-]*-//'`
+- ;;
+- ppc64le | powerpc64little | ppc64-le | powerpc64-little)
+- basic_machine=powerpc64le-unknown
+- ;;
+- ppc64le-* | powerpc64little-*)
+- basic_machine=powerpc64le-`echo $basic_machine | sed 's/^[^-]*-//'`
++ power)
++ cpu=power
++ vendor=ibm
+ ;;
+ ps2)
+- basic_machine=i386-ibm
+- ;;
+- pw32)
+- basic_machine=i586-unknown
+- os=-pw32
+- ;;
+- rdos | rdos64)
+- basic_machine=x86_64-pc
+- os=-rdos
+- ;;
+- rdos32)
+- basic_machine=i386-pc
+- os=-rdos
+- ;;
+- rom68k)
+- basic_machine=m68k-rom68k
+- os=-coff
++ cpu=i386
++ vendor=ibm
+ ;;
+ rm[46]00)
+- basic_machine=mips-siemens
++ cpu=mips
++ vendor=siemens
+ ;;
+ rtpc | rtpc-*)
+- basic_machine=romp-ibm
++ cpu=romp
++ vendor=ibm
+ ;;
+- s390 | s390-*)
+- basic_machine=s390-ibm
++ sde)
++ cpu=mipsisa32
++ vendor=sde
++ basic_os=${basic_os:-elf}
++ ;;
++ simso-wrs)
++ cpu=sparclite
++ vendor=wrs
++ basic_os=vxworks
+ ;;
+- s390x | s390x-*)
+- basic_machine=s390x-ibm
++ tower | tower-32)
++ cpu=m68k
++ vendor=ncr
+ ;;
+- sa29200)
+- basic_machine=a29k-amd
+- os=-udi
++ vpp*|vx|vx-*)
++ cpu=f301
++ vendor=fujitsu
+ ;;
+- sb1)
+- basic_machine=mipsisa64sb1-unknown
++ w65)
++ cpu=w65
++ vendor=wdc
+ ;;
+- sb1el)
+- basic_machine=mipsisa64sb1el-unknown
++ w89k-*)
++ cpu=hppa1.1
++ vendor=winbond
++ basic_os=proelf
+ ;;
+- sde)
+- basic_machine=mipsisa32-sde
+- os=-elf
++ none)
++ cpu=none
++ vendor=none
+ ;;
+- sei)
+- basic_machine=mips-sei
+- os=-seiux
++ leon|leon[3-9])
++ cpu=sparc
++ vendor=$basic_machine
++ ;;
++ leon-*|leon[3-9]-*)
++ cpu=sparc
++ vendor=`echo "$basic_machine" | sed 's/-.*//'`
++ ;;
++
++ *-*)
++ # shellcheck disable=SC2162
++ saved_IFS=$IFS
++ IFS="-" read cpu vendor <&2
+- exit 1
++ # Recognize the canonical CPU types that are allowed with any
++ # company name.
++ case $cpu in
++ 1750a | 580 \
++ | a29k \
++ | aarch64 | aarch64_be \
++ | abacus \
++ | alpha | alphaev[4-8] | alphaev56 | alphaev6[78] \
++ | alpha64 | alpha64ev[4-8] | alpha64ev56 | alpha64ev6[78] \
++ | alphapca5[67] | alpha64pca5[67] \
++ | am33_2.0 \
++ | amdgcn \
++ | arc | arceb | arc32 | arc64 \
++ | arm | arm[lb]e | arme[lb] | armv* \
++ | avr | avr32 \
++ | asmjs \
++ | ba \
++ | be32 | be64 \
++ | bfin | bpf | bs2000 \
++ | c[123]* | c30 | [cjt]90 | c4x \
++ | c8051 | clipper | craynv | csky | cydra \
++ | d10v | d30v | dlx | dsp16xx \
++ | e2k | elxsi | epiphany \
++ | f30[01] | f700 | fido | fr30 | frv | ft32 | fx80 \
++ | h8300 | h8500 \
++ | hppa | hppa1.[01] | hppa2.0 | hppa2.0[nw] | hppa64 \
++ | hexagon \
++ | i370 | i*86 | i860 | i960 | ia16 | ia64 \
++ | ip2k | iq2000 \
++ | k1om \
++ | le32 | le64 \
++ | lm32 \
++ | loongarch32 | loongarch64 | loongarchx32 \
++ | m32c | m32r | m32rle \
++ | m5200 | m68000 | m680[012346]0 | m68360 | m683?2 | m68k \
++ | m6811 | m68hc11 | m6812 | m68hc12 | m68hcs12x \
++ | m88110 | m88k | maxq | mb | mcore | mep | metag \
++ | microblaze | microblazeel \
++ | mips | mipsbe | mipseb | mipsel | mipsle \
++ | mips16 \
++ | mips64 | mips64eb | mips64el \
++ | mips64octeon | mips64octeonel \
++ | mips64orion | mips64orionel \
++ | mips64r5900 | mips64r5900el \
++ | mips64vr | mips64vrel \
++ | mips64vr4100 | mips64vr4100el \
++ | mips64vr4300 | mips64vr4300el \
++ | mips64vr5000 | mips64vr5000el \
++ | mips64vr5900 | mips64vr5900el \
++ | mipsisa32 | mipsisa32el \
++ | mipsisa32r2 | mipsisa32r2el \
++ | mipsisa32r3 | mipsisa32r3el \
++ | mipsisa32r5 | mipsisa32r5el \
++ | mipsisa32r6 | mipsisa32r6el \
++ | mipsisa64 | mipsisa64el \
++ | mipsisa64r2 | mipsisa64r2el \
++ | mipsisa64r3 | mipsisa64r3el \
++ | mipsisa64r5 | mipsisa64r5el \
++ | mipsisa64r6 | mipsisa64r6el \
++ | mipsisa64sb1 | mipsisa64sb1el \
++ | mipsisa64sr71k | mipsisa64sr71kel \
++ | mipsr5900 | mipsr5900el \
++ | mipstx39 | mipstx39el \
++ | mmix \
++ | mn10200 | mn10300 \
++ | moxie \
++ | mt \
++ | msp430 \
++ | nds32 | nds32le | nds32be \
++ | nfp \
++ | nios | nios2 | nios2eb | nios2el \
++ | none | np1 | ns16k | ns32k | nvptx \
++ | open8 \
++ | or1k* \
++ | or32 \
++ | orion \
++ | picochip \
++ | pdp10 | pdp11 | pj | pjl | pn | power \
++ | powerpc | powerpc64 | powerpc64le | powerpcle | powerpcspe \
++ | pru \
++ | pyramid \
++ | riscv | riscv32 | riscv32be | riscv64 | riscv64be \
++ | rl78 | romp | rs6000 | rx \
++ | s390 | s390x \
++ | score \
++ | sh | shl \
++ | sh[1234] | sh[24]a | sh[24]ae[lb] | sh[23]e | she[lb] | sh[lb]e \
++ | sh[1234]e[lb] | sh[12345][lb]e | sh[23]ele | sh64 | sh64le \
++ | sparc | sparc64 | sparc64b | sparc64v | sparc86x | sparclet \
++ | sparclite \
++ | sparcv8 | sparcv9 | sparcv9b | sparcv9v | sv1 | sx* \
++ | spu \
++ | tahoe \
++ | thumbv7* \
++ | tic30 | tic4x | tic54x | tic55x | tic6x | tic80 \
++ | tron \
++ | ubicom32 \
++ | v70 | v850 | v850e | v850e1 | v850es | v850e2 | v850e2v3 \
++ | vax \
++ | visium \
++ | w65 \
++ | wasm32 | wasm64 \
++ | we32k \
++ | x86 | x86_64 | xc16x | xgate | xps100 \
++ | xstormy16 | xtensa* \
++ | ymp \
++ | z8k | z80)
++ ;;
++
++ *)
++ echo Invalid configuration \`"$1"\': machine \`"$cpu-$vendor"\' not recognized 1>&2
++ exit 1
++ ;;
++ esac
+ ;;
+ esac
+
+ # Here we canonicalize certain aliases for manufacturers.
+-case $basic_machine in
+- *-digital*)
+- basic_machine=`echo $basic_machine | sed 's/digital.*/dec/'`
++case $vendor in
++ digital*)
++ vendor=dec
+ ;;
+- *-commodore*)
+- basic_machine=`echo $basic_machine | sed 's/commodore.*/cbm/'`
++ commodore*)
++ vendor=cbm
+ ;;
+ *)
+ ;;
+@@ -1323,200 +1301,215 @@
+
+ # Decode manufacturer-specific aliases for certain operating systems.
+
+-if [ x"$os" != x"" ]
++if test x$basic_os != x
+ then
++
++# First recognize some ad-hoc caes, or perhaps split kernel-os, or else just
++# set os.
++case $basic_os in
++ gnu/linux*)
++ kernel=linux
++ os=`echo "$basic_os" | sed -e 's|gnu/linux|gnu|'`
++ ;;
++ os2-emx)
++ kernel=os2
++ os=`echo "$basic_os" | sed -e 's|os2-emx|emx|'`
++ ;;
++ nto-qnx*)
++ kernel=nto
++ os=`echo "$basic_os" | sed -e 's|nto-qnx|qnx|'`
++ ;;
++ *-*)
++ # shellcheck disable=SC2162
++ saved_IFS=$IFS
++ IFS="-" read kernel os <&2
+- exit 1
++ # No normalization, but not necessarily accepted, that comes below.
+ ;;
+ esac
++
+ else
+
+ # Here we handle the default operating systems that come with various machines.
+@@ -1529,264 +1522,362 @@
+ # will signal an error saying that MANUFACTURER isn't an operating
+ # system, and we'll never get to this point.
+
+-case $basic_machine in
++kernel=
++case $cpu-$vendor in
+ score-*)
+- os=-elf
++ os=elf
+ ;;
+ spu-*)
+- os=-elf
++ os=elf
+ ;;
+ *-acorn)
+- os=-riscix1.2
++ os=riscix1.2
+ ;;
+ arm*-rebel)
+- os=-linux
++ kernel=linux
++ os=gnu
+ ;;
+ arm*-semi)
+- os=-aout
++ os=aout
+ ;;
+ c4x-* | tic4x-*)
+- os=-coff
++ os=coff
+ ;;
+ c8051-*)
+- os=-elf
++ os=elf
++ ;;
++ clipper-intergraph)
++ os=clix
+ ;;
+ hexagon-*)
+- os=-elf
++ os=elf
+ ;;
+ tic54x-*)
+- os=-coff
++ os=coff
+ ;;
+ tic55x-*)
+- os=-coff
++ os=coff
+ ;;
+ tic6x-*)
+- os=-coff
++ os=coff
+ ;;
+ # This must come before the *-dec entry.
+ pdp10-*)
+- os=-tops20
++ os=tops20
+ ;;
+ pdp11-*)
+- os=-none
++ os=none
+ ;;
+ *-dec | vax-*)
+- os=-ultrix4.2
++ os=ultrix4.2
+ ;;
+ m68*-apollo)
+- os=-domain
++ os=domain
+ ;;
+ i386-sun)
+- os=-sunos4.0.2
++ os=sunos4.0.2
+ ;;
+ m68000-sun)
+- os=-sunos3
++ os=sunos3
+ ;;
+ m68*-cisco)
+- os=-aout
++ os=aout
+ ;;
+ mep-*)
+- os=-elf
++ os=elf
+ ;;
+ mips*-cisco)
+- os=-elf
++ os=elf
+ ;;
+ mips*-*)
+- os=-elf
+- ;;
+- or1k-*)
+- os=-elf
++ os=elf
+ ;;
+ or32-*)
+- os=-coff
++ os=coff
+ ;;
+ *-tti) # must be before sparc entry or we get the wrong os.
+- os=-sysv3
++ os=sysv3
+ ;;
+ sparc-* | *-sun)
+- os=-sunos4.1.1
++ os=sunos4.1.1
+ ;;
+- *-be)
+- os=-beos
++ pru-*)
++ os=elf
+ ;;
+- *-haiku)
+- os=-haiku
++ *-be)
++ os=beos
+ ;;
+ *-ibm)
+- os=-aix
++ os=aix
+ ;;
+ *-knuth)
+- os=-mmixware
++ os=mmixware
+ ;;
+ *-wec)
+- os=-proelf
++ os=proelf
+ ;;
+ *-winbond)
+- os=-proelf
++ os=proelf
+ ;;
+ *-oki)
+- os=-proelf
++ os=proelf
+ ;;
+ *-hp)
+- os=-hpux
++ os=hpux
+ ;;
+ *-hitachi)
+- os=-hiux
++ os=hiux
+ ;;
+ i860-* | *-att | *-ncr | *-altos | *-motorola | *-convergent)
+- os=-sysv
++ os=sysv
+ ;;
+ *-cbm)
+- os=-amigaos
++ os=amigaos
+ ;;
+ *-dg)
+- os=-dgux
++ os=dgux
+ ;;
+ *-dolphin)
+- os=-sysv3
++ os=sysv3
+ ;;
+ m68k-ccur)
+- os=-rtu
++ os=rtu
+ ;;
+ m88k-omron*)
+- os=-luna
++ os=luna
+ ;;
+- *-next )
+- os=-nextstep
++ *-next)
++ os=nextstep
+ ;;
+ *-sequent)
+- os=-ptx
++ os=ptx
+ ;;
+ *-crds)
+- os=-unos
++ os=unos
+ ;;
+ *-ns)
+- os=-genix
++ os=genix
+ ;;
+ i370-*)
+- os=-mvs
+- ;;
+- *-next)
+- os=-nextstep3
++ os=mvs
+ ;;
+ *-gould)
+- os=-sysv
++ os=sysv
+ ;;
+ *-highlevel)
+- os=-bsd
++ os=bsd
+ ;;
+ *-encore)
+- os=-bsd
++ os=bsd
+ ;;
+ *-sgi)
+- os=-irix
++ os=irix
+ ;;
+ *-siemens)
+- os=-sysv4
++ os=sysv4
+ ;;
+ *-masscomp)
+- os=-rtu
++ os=rtu
+ ;;
+ f30[01]-fujitsu | f700-fujitsu)
+- os=-uxpv
++ os=uxpv
+ ;;
+ *-rom68k)
+- os=-coff
++ os=coff
+ ;;
+ *-*bug)
+- os=-coff
++ os=coff
+ ;;
+ *-apple)
+- os=-macos
++ os=macos
+ ;;
+ *-atari*)
+- os=-mint
++ os=mint
++ ;;
++ *-wrs)
++ os=vxworks
+ ;;
+ *)
+- os=-none
++ os=none
+ ;;
+ esac
++
+ fi
+
++# Now, validate our (potentially fixed-up) OS.
++case $os in
++ # Sometimes we do "kernel-libc", so those need to count as OSes.
++ musl* | newlib* | relibc* | uclibc*)
++ ;;
++ # Likewise for "kernel-abi"
++ eabi* | gnueabi*)
++ ;;
++ # VxWorks passes extra cpu info in the 4th filed.
++ simlinux | simwindows | spe)
++ ;;
++ # Now accept the basic system types.
++ # The portable systems comes first.
++ # Each alternative MUST end in a * to match a version number.
++ gnu* | android* | bsd* | mach* | minix* | genix* | ultrix* | irix* \
++ | *vms* | esix* | aix* | cnk* | sunos | sunos[34]* \
++ | hpux* | unos* | osf* | luna* | dgux* | auroraux* | solaris* \
++ | sym* | plan9* | psp* | sim* | xray* | os68k* | v88r* \
++ | hiux* | abug | nacl* | netware* | windows* \
++ | os9* | macos* | osx* | ios* \
++ | mpw* | magic* | mmixware* | mon960* | lnews* \
++ | amigaos* | amigados* | msdos* | newsos* | unicos* | aof* \
++ | aos* | aros* | cloudabi* | sortix* | twizzler* \
++ | nindy* | vxsim* | vxworks* | ebmon* | hms* | mvs* \
++ | clix* | riscos* | uniplus* | iris* | isc* | rtu* | xenix* \
++ | mirbsd* | netbsd* | dicos* | openedition* | ose* \
++ | bitrig* | openbsd* | secbsd* | solidbsd* | libertybsd* | os108* \
++ | ekkobsd* | freebsd* | riscix* | lynxos* | os400* \
++ | bosx* | nextstep* | cxux* | aout* | elf* | oabi* \
++ | ptx* | coff* | ecoff* | winnt* | domain* | vsta* \
++ | udi* | lites* | ieee* | go32* | aux* | hcos* \
++ | chorusrdb* | cegcc* | glidix* | serenity* \
++ | cygwin* | msys* | pe* | moss* | proelf* | rtems* \
++ | midipix* | mingw32* | mingw64* | mint* \
++ | uxpv* | beos* | mpeix* | udk* | moxiebox* \
++ | interix* | uwin* | mks* | rhapsody* | darwin* \
++ | openstep* | oskit* | conix* | pw32* | nonstopux* \
++ | storm-chaos* | tops10* | tenex* | tops20* | its* \
++ | os2* | vos* | palmos* | uclinux* | nucleus* | morphos* \
++ | scout* | superux* | sysv* | rtmk* | tpf* | windiss* \
++ | powermax* | dnix* | nx6 | nx7 | sei* | dragonfly* \
++ | skyos* | haiku* | rdos* | toppers* | drops* | es* \
++ | onefs* | tirtos* | phoenix* | fuchsia* | redox* | bme* \
++ | midnightbsd* | amdhsa* | unleashed* | emscripten* | wasi* \
++ | nsk* | powerunix* | genode* | zvmoe* | qnx* | emx* | zephyr*)
++ ;;
++ # This one is extra strict with allowed versions
++ sco3.2v2 | sco3.2v[4-9]* | sco5v6*)
++ # Don't forget version if it is 3.2v4 or newer.
++ ;;
++ none)
++ ;;
++ *)
++ echo Invalid configuration \`"$1"\': OS \`"$os"\' not recognized 1>&2
++ exit 1
++ ;;
++esac
++
++# As a final step for OS-related things, validate the OS-kernel combination
++# (given a valid OS), if there is a kernel.
++case $kernel-$os in
++ linux-gnu* | linux-dietlibc* | linux-android* | linux-newlib* \
++ | linux-musl* | linux-relibc* | linux-uclibc* )
++ ;;
++ uclinux-uclibc* )
++ ;;
++ -dietlibc* | -newlib* | -musl* | -relibc* | -uclibc* )
++ # These are just libc implementations, not actual OSes, and thus
++ # require a kernel.
++ echo "Invalid configuration \`$1': libc \`$os' needs explicit kernel." 1>&2
++ exit 1
++ ;;
++ kfreebsd*-gnu* | kopensolaris*-gnu*)
++ ;;
++ vxworks-simlinux | vxworks-simwindows | vxworks-spe)
++ ;;
++ nto-qnx*)
++ ;;
++ os2-emx)
++ ;;
++ *-eabi* | *-gnueabi*)
++ ;;
++ -*)
++ # Blank kernel with real OS is always fine.
++ ;;
++ *-*)
++ echo "Invalid configuration \`$1': Kernel \`$kernel' not known to work with OS \`$os'." 1>&2
++ exit 1
++ ;;
++esac
++
+ # Here we handle the case where we know the os, and the CPU type, but not the
+ # manufacturer. We pick the logical manufacturer.
+-vendor=unknown
+-case $basic_machine in
+- *-unknown)
+- case $os in
+- -riscix*)
++case $vendor in
++ unknown)
++ case $cpu-$os in
++ *-riscix*)
+ vendor=acorn
+ ;;
+- -sunos*)
++ *-sunos*)
+ vendor=sun
+ ;;
+- -cnk*|-aix*)
++ *-cnk* | *-aix*)
+ vendor=ibm
+ ;;
+- -beos*)
++ *-beos*)
+ vendor=be
+ ;;
+- -hpux*)
++ *-hpux*)
+ vendor=hp
+ ;;
+- -mpeix*)
++ *-mpeix*)
+ vendor=hp
+ ;;
+- -hiux*)
++ *-hiux*)
+ vendor=hitachi
+ ;;
+- -unos*)
++ *-unos*)
+ vendor=crds
+ ;;
+- -dgux*)
++ *-dgux*)
+ vendor=dg
+ ;;
+- -luna*)
++ *-luna*)
+ vendor=omron
+ ;;
+- -genix*)
++ *-genix*)
+ vendor=ns
+ ;;
+- -mvs* | -opened*)
++ *-clix*)
++ vendor=intergraph
++ ;;
++ *-mvs* | *-opened*)
++ vendor=ibm
++ ;;
++ *-os400*)
+ vendor=ibm
+ ;;
+- -os400*)
++ s390-* | s390x-*)
+ vendor=ibm
+ ;;
+- -ptx*)
++ *-ptx*)
+ vendor=sequent
+ ;;
+- -tpf*)
++ *-tpf*)
+ vendor=ibm
+ ;;
+- -vxsim* | -vxworks* | -windiss*)
++ *-vxsim* | *-vxworks* | *-windiss*)
+ vendor=wrs
+ ;;
+- -aux*)
++ *-aux*)
+ vendor=apple
+ ;;
+- -hms*)
++ *-hms*)
+ vendor=hitachi
+ ;;
+- -mpw* | -macos*)
++ *-mpw* | *-macos*)
+ vendor=apple
+ ;;
+- -*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*)
++ *-*mint | *-mint[0-9]* | *-*MiNT | *-MiNT[0-9]*)
+ vendor=atari
+ ;;
+- -vos*)
++ *-vos*)
+ vendor=stratus
+ ;;
+ esac
+- basic_machine=`echo $basic_machine | sed "s/unknown/$vendor/"`
+ ;;
+ esac
+
+-echo $basic_machine$os
++echo "$cpu-$vendor-${kernel:+$kernel-}$os"
+ exit
+
+ # Local variables:
+-# eval: (add-hook 'write-file-hooks 'time-stamp)
++# eval: (add-hook 'before-save-hook 'time-stamp)
+ # time-stamp-start: "timestamp='"
+ # time-stamp-format: "%:y-%02m-%02d"
+ # time-stamp-end: "'"
diff --git a/kiwixbuild/platforms/__init__.py b/kiwixbuild/platforms/__init__.py
index c76338bb..b73ddbc2 100644
--- a/kiwixbuild/platforms/__init__.py
+++ b/kiwixbuild/platforms/__init__.py
@@ -9,5 +9,6 @@
ios,
native,
neutral,
- win32
+ win32,
+ wasm
)
diff --git a/kiwixbuild/platforms/wasm.py b/kiwixbuild/platforms/wasm.py
new file mode 100644
index 00000000..31b71a69
--- /dev/null
+++ b/kiwixbuild/platforms/wasm.py
@@ -0,0 +1,100 @@
+from .base import PlatformInfo
+
+from kiwixbuild.utils import pj
+from kiwixbuild._global import get_target_step
+
+
+class WasmPlatformInfo(PlatformInfo):
+ name = 'wasm'
+ static = True
+ build = 'wasm'
+ arch_full = 'wasm64-emscripten'
+ #arch_full = 'wasm64-linux'
+ toolchain_names = ['emsdk']
+ compatible_hosts = ['fedora', 'debian']
+ exe_wrapper_def = ""
+
+ def get_cross_config(self):
+ return {
+ 'binaries': self.binaries,
+ 'exe_wrapper_def': '',
+ 'root_path': self.root_path,
+ 'extra_libs': [],
+ 'extra_cflags': [],
+ 'host_machine': {
+ 'system': 'emscripten',
+ 'lsystem': 'emscripten',
+ 'cpu_family': 'wasm64',
+ 'cpu': 'wasm64',
+ 'endian': 'little',
+ 'abi': ''
+ }
+ }
+
+ @property
+ def wasm_sdk(self):
+ return get_target_step('emsdk', self.name)
+
+ @property
+ def install_path(self):
+ return self.wasm_sdk.install_path
+
+ @property
+ def root_path(self):
+ return self.install_path
+
+ @property
+ def binaries(self):
+ binaries = (('CC', 'emcc'),
+ ('CXX', 'em++'),
+ ('AR', 'emar'),
+ ('STRIP', 'emstrip'),
+ ('WINDRES', 'windres'),
+ ('RANLIB', 'emranlib'),
+ ('LD', 'wasm-ld'))
+ binaries = {k:pj(self.install_path, 'upstream', 'emscripten', v)
+ for k,v in binaries}
+ binaries['PKGCONFIG'] = 'pkg-config'
+ return binaries
+
+ @property
+ def configure_option(self):
+ #return ""
+ return '--host={}'.format(self.arch_full)
+
+ @property
+ def configure_wrapper(self):
+ return "emconfigure"
+
+ @property
+ def make_wrapper(self):
+ return "emmake"
+
+ def get_bin_dir(self):
+ return [pj(self.install_path, 'bin')]
+
+ def get_env(self):
+ env = super().get_env()
+ env['PATH'] = ':'.join([
+ env['PATH'],
+ self.install_path,
+ pj(self.install_path, 'upstream', 'emscripten'),
+ pj(self.install_path, 'node', '14.18.2_64bit', 'bin')
+ ])
+ env['EMSDK'] = self.install_path
+ env['EMSDK_NODE'] = pj(self.install_path, 'node', '14.18.2_64bit', 'bin', 'node')
+ return env
+
+ def set_comp_flags(self, env):
+ super().set_comp_flags(env)
+ env['CFLAGS'] = " -Wp,-D_FORTIFY_SOURCE=2 -fexceptions --param=ssp-buffer-size=4 "+env['CFLAGS']
+ env['CXXFLAGS'] = " -Wp,-D_FORTIFY_SOURCE=2 -fexceptions --param=ssp-buffer-size=4 "+env['CXXFLAGS']
+
+ def set_compiler(self, env):
+ for k, v in self.binaries.items():
+ env[k] = v
+
+ def finalize_setup(self):
+ super().finalize_setup()
+ self.buildEnv.cmake_crossfile = self._gen_crossfile('cmake_cross_file.txt')
+ self.buildEnv.meson_crossfile = self._gen_crossfile('meson_cross_file.txt')
diff --git a/kiwixbuild/versions.py b/kiwixbuild/versions.py
index 19b2a49d..9055531a 100644
--- a/kiwixbuild/versions.py
+++ b/kiwixbuild/versions.py
@@ -39,11 +39,11 @@
# This is the "version" of the whole base_deps_versions dict.
# Change this when you change base_deps_versions.
-base_deps_meta_version = '78'
+base_deps_meta_version = '79'
base_deps_versions = {
'zlib' : '1.2.12',
- 'lzma' : '5.2.4',
+ 'lzma' : '5.2.6',
'zstd' : '1.5.2',
'docoptcpp' : '0.6.2',
'uuid' : '1.43.4',