From 9d3663578161af5d168382f95730e8e04c3cd3bf Mon Sep 17 00:00:00 2001 From: oreo639 Date: Sun, 9 Feb 2025 19:47:00 -0800 Subject: [PATCH] New package: mozjs128-128.7.0 --- common/shlibs | 1 + srcpkgs/mozjs128-devel | 1 + srcpkgs/mozjs128/patches/001-fix-soname.patch | 26 +++++ .../mozjs128/patches/002-copy-headers.patch | 38 +++++++ .../mozjs128/patches/003-tests-timeout.patch | 22 ++++ .../004-icu-sources-data-py-decouple.patch | 29 +++++ ...cu-sources-data-write-command-stderr.patch | 44 ++++++++ srcpkgs/mozjs128/patches/006-emitter.patch | 67 ++++++++++++ ...-tests-use-native-temporarydirectory.patch | 65 ++++++++++++ srcpkgs/mozjs128/patches/008-init-patch.patch | 28 +++++ .../patches/009-sloppy-m4-detection.patch | 29 +++++ .../011-failing-tests-ppc64-s390x.patch | 36 +++++++ .../013-disable-spidermonkey-jslint.patch | 26 +++++ .../mozjs128/patches/014-rust-target.patch | 28 +++++ .../patches/015-drop-rustc-validation.patch | 80 ++++++++++++++ .../mozjs128/patches/017-no-lto-readelf.patch | 35 ++++++ .../mozjs128/patches/MOZ_NO_RUST_LTO.patch | 18 ++++ srcpkgs/mozjs128/patches/armv6l-isb.patch | 16 +++ ...cd70e034b4ccdccf8b7d9243ffa931a46c78.patch | 100 ++++++++++++++++++ .../mozjs128/patches/fix-build-ppc32.patch | 18 ++++ .../mozjs128/patches/fix-i386-fdlibm.patch | 18 ++++ srcpkgs/mozjs128/template | 84 +++++++++++++++ srcpkgs/mozjs128/update | 2 + 23 files changed, 811 insertions(+) create mode 120000 srcpkgs/mozjs128-devel create mode 100644 srcpkgs/mozjs128/patches/001-fix-soname.patch create mode 100644 srcpkgs/mozjs128/patches/002-copy-headers.patch create mode 100644 srcpkgs/mozjs128/patches/003-tests-timeout.patch create mode 100644 srcpkgs/mozjs128/patches/004-icu-sources-data-py-decouple.patch create mode 100644 srcpkgs/mozjs128/patches/005-icu-sources-data-write-command-stderr.patch create mode 100644 srcpkgs/mozjs128/patches/006-emitter.patch create mode 100644 srcpkgs/mozjs128/patches/007-tests-use-native-temporarydirectory.patch create mode 100644 srcpkgs/mozjs128/patches/008-init-patch.patch create mode 100644 srcpkgs/mozjs128/patches/009-sloppy-m4-detection.patch create mode 100644 srcpkgs/mozjs128/patches/011-failing-tests-ppc64-s390x.patch create mode 100644 srcpkgs/mozjs128/patches/013-disable-spidermonkey-jslint.patch create mode 100644 srcpkgs/mozjs128/patches/014-rust-target.patch create mode 100644 srcpkgs/mozjs128/patches/015-drop-rustc-validation.patch create mode 100644 srcpkgs/mozjs128/patches/017-no-lto-readelf.patch create mode 100644 srcpkgs/mozjs128/patches/MOZ_NO_RUST_LTO.patch create mode 100644 srcpkgs/mozjs128/patches/armv6l-isb.patch create mode 100644 srcpkgs/mozjs128/patches/d535cd70e034b4ccdccf8b7d9243ffa931a46c78.patch create mode 100644 srcpkgs/mozjs128/patches/fix-build-ppc32.patch create mode 100644 srcpkgs/mozjs128/patches/fix-i386-fdlibm.patch create mode 100644 srcpkgs/mozjs128/template create mode 100644 srcpkgs/mozjs128/update diff --git a/common/shlibs b/common/shlibs index 54a0371f306..9b75999b479 100644 --- a/common/shlibs +++ b/common/shlibs @@ -3583,6 +3583,7 @@ libKF5Syndication.so.5 syndication-5.50.0_1 liblqr-1.so.0 liblqr-0.4.2_1 libmozjs-102.so.0 mozjs102-102.3.0_1 libmozjs-115.so.0 mozjs115-115.8.0_1 +libmozjs-128.so.0 mozjs128-128.7.0_1 libebur128.so.1 libebur128-1.2.4_1 libgtksourceview-4.so.0 gtksourceview4-4.0.2_1 libgtksourceview-5.so.0 gtksourceview5-5.2.0_1 diff --git a/srcpkgs/mozjs128-devel b/srcpkgs/mozjs128-devel new file mode 120000 index 00000000000..27b4d683db8 --- /dev/null +++ b/srcpkgs/mozjs128-devel @@ -0,0 +1 @@ +mozjs128 \ No newline at end of file diff --git a/srcpkgs/mozjs128/patches/001-fix-soname.patch b/srcpkgs/mozjs128/patches/001-fix-soname.patch new file mode 100644 index 00000000000..a319d9e975e --- /dev/null +++ b/srcpkgs/mozjs128/patches/001-fix-soname.patch @@ -0,0 +1,26 @@ +From d21c7cb9343d8c495d987e71be0f35887574c820 Mon Sep 17 00:00:00 2001 +From: =?UTF-8?q?Franti=C5=A1ek=20Zatloukal?= +Date: Wed, 15 Jul 2020 08:21:47 +0200 +Subject: [PATCH] Add soname switch to linker, regardless of Operating System + +Fix backported from Debian: http://bugs.debian.org/746705 +--- + config/rules.mk | 2 ++ + 1 file changed, 2 insertions(+) + +diff --git a/config/rules.mk b/config/rules.mk +index 0f9b2ac..f6b4efe 100644 +--- a/config/rules.mk ++++ b/config/rules.mk +@@ -285,6 +285,8 @@ ifeq ($(OS_ARCH),GNU) + OS_CPPFLAGS += -DPATH_MAX=1024 -DMAXPATHLEN=1024 + endif + ++EXTRA_DSO_LDOPTS += -Wl,-soname,lib$(JS_LIBRARY_NAME).so.0 ++ + # + # MINGW32 + # +-- +2.31.1 + diff --git a/srcpkgs/mozjs128/patches/002-copy-headers.patch b/srcpkgs/mozjs128/patches/002-copy-headers.patch new file mode 100644 index 00000000000..aafe1aa84bd --- /dev/null +++ b/srcpkgs/mozjs128/patches/002-copy-headers.patch @@ -0,0 +1,38 @@ +From 3b3c8e37cca418e07bdeceaf3a601805df28d925 Mon Sep 17 00:00:00 2001 +From: =?UTF-8?q?Franti=C5=A1ek=20Zatloukal?= +Date: Wed, 15 Jul 2020 08:27:39 +0200 +Subject: [PATCH] build: Copy headers on install instead of symlinking + +Patch by Philip Chimento ported forward to mozjs78 +--- + python/mozbuild/mozbuild/backend/recursivemake.py | 6 +++--- + 1 file changed, 3 insertions(+), 3 deletions(-) + +diff --git a/python/mozbuild/mozbuild/backend/recursivemake.py b/python/mozbuild/mozbuild/backend/recursivemake.py +index d964466..0285ad9 100644 +--- a/python/mozbuild/mozbuild/backend/recursivemake.py ++++ b/python/mozbuild/mozbuild/backend/recursivemake.py +@@ -1568,9 +1568,9 @@ class RecursiveMakeBackend(MakeBackend): + " of srcdir-relative or absolute paths." + ) + +- install_manifest.add_pattern_link(basepath, wild, dest_dir) ++ install_manifest.add_pattern_copy(basepath, wild, dest_dir) + else: +- install_manifest.add_pattern_link(f.srcdir, f, dest_dir) ++ install_manifest.add_pattern_copy(f.srcdir, f, dest_dir) + elif isinstance(f, AbsolutePath): + if not f.full_path.lower().endswith((".dll", ".pdb", ".so")): + raise Exception( +@@ -1581,7 +1581,7 @@ class RecursiveMakeBackend(MakeBackend): + install_manifest.add_optional_exists(dest_file) + absolute_files.append(f.full_path) + else: +- install_manifest.add_link(f.full_path, dest_file) ++ install_manifest.add_copy(f.full_path, dest_file) + else: + install_manifest.add_optional_exists(dest_file) + objdir_files.append(self._pretty_path(f, backend_file)) +-- +2.31.1 + diff --git a/srcpkgs/mozjs128/patches/003-tests-timeout.patch b/srcpkgs/mozjs128/patches/003-tests-timeout.patch new file mode 100644 index 00000000000..3c2f18267e1 --- /dev/null +++ b/srcpkgs/mozjs128/patches/003-tests-timeout.patch @@ -0,0 +1,22 @@ +From: Adrian Bunk +Date: Tue, 3 Jul 2018 10:03:37 +0100 +Subject: Increase the test timeout for slower buildds + +Bug-Debian: https://bugs.debian.org/878284 +--- + js/src/Makefile.in | 2 +- + 1 file changed, 1 insertion(+), 1 deletion(-) + +diff --git a/js/src/Makefile.in b/js/src/Makefile.in +index 9202f5e..20c8cf1 100644 +--- a/js/src/Makefile.in ++++ b/js/src/Makefile.in +@@ -53,7 +53,7 @@ check:: check-js-msg + + check-jstests: + $(PYTHON3) -u $(srcdir)/tests/jstests.py \ +- --no-progress --format=automation --timeout 300 \ ++ --no-progress --format=automation --timeout 600 \ + $(JSTESTS_EXTRA_ARGS) \ + $(DIST)/bin/js$(BIN_SUFFIX) + diff --git a/srcpkgs/mozjs128/patches/004-icu-sources-data-py-decouple.patch b/srcpkgs/mozjs128/patches/004-icu-sources-data-py-decouple.patch new file mode 100644 index 00000000000..8572c21fd4e --- /dev/null +++ b/srcpkgs/mozjs128/patches/004-icu-sources-data-py-decouple.patch @@ -0,0 +1,29 @@ +From: Simon McVittie +Date: Mon, 9 Oct 2017 09:22:12 +0100 +Subject: icu_sources_data.py: Decouple from Mozilla build system + +mozpack.path is a wrapper around os.path that normalizes path +separators on Windows, but on Unix we only have one path separator +so there's nothing to normalize. Avoid needing to import all of it. +--- + intl/icu_sources_data.py | 4 +++- + 1 file changed, 3 insertions(+), 1 deletion(-) + +diff --git a/intl/icu_sources_data.py b/intl/icu_sources_data.py +index 2936df9..4db52af 100644 +--- a/intl/icu_sources_data.py ++++ b/intl/icu_sources_data.py +@@ -21,7 +21,9 @@ import subprocess + import sys + import tempfile + +-from mozpack import path as mozpath ++# Close enough ++import os.path as mozpath ++mozpath.normsep = lambda p: p + + # The following files have been determined to be dead/unused by a + # semi-automated analysis. You can just remove any of the files below +-- +2.31.1 + diff --git a/srcpkgs/mozjs128/patches/005-icu-sources-data-write-command-stderr.patch b/srcpkgs/mozjs128/patches/005-icu-sources-data-write-command-stderr.patch new file mode 100644 index 00000000000..84684250ce4 --- /dev/null +++ b/srcpkgs/mozjs128/patches/005-icu-sources-data-write-command-stderr.patch @@ -0,0 +1,44 @@ +From: Simon McVittie +Date: Mon, 9 Oct 2017 09:23:14 +0100 +Subject: icu_sources_data: Write command output to our stderr + +Saying "See output in /tmp/foobar" is all very well for a developer +build, but on a buildd our /tmp is going to get thrown away after +the build. Just log the usual way instead. +--- + intl/icu_sources_data.py | 16 ++++------------ + 1 file changed, 4 insertions(+), 12 deletions(-) + +diff --git a/intl/icu_sources_data.py b/intl/icu_sources_data.py +index 4db52af..d62960d 100644 +--- a/intl/icu_sources_data.py ++++ b/intl/icu_sources_data.py +@@ -188,21 +188,13 @@ def update_sources(topsrcdir): + + def try_run(name, command, cwd=None, **kwargs): + try: +- with tempfile.NamedTemporaryFile(prefix=name, delete=False) as f: +- subprocess.check_call( +- command, cwd=cwd, stdout=f, stderr=subprocess.STDOUT, **kwargs +- ) +- except subprocess.CalledProcessError: +- print( +- """Error running "{}" in directory {} +- See output in {}""".format( +- " ".join(command), cwd, f.name +- ), +- file=sys.stderr, ++ subprocess.check_call( ++ command, cwd=cwd, stdout=sys.stderr, stderr=subprocess.STDOUT, **kwargs + ) ++ except subprocess.CalledProcessError: ++ print('''Error running "{}" in directory {}'''.format(' '.join(command), cwd), file=sys.stderr) + return False + else: +- os.unlink(f.name) + return True + + +-- +2.31.1 + diff --git a/srcpkgs/mozjs128/patches/006-emitter.patch b/srcpkgs/mozjs128/patches/006-emitter.patch new file mode 100644 index 00000000000..556bebd257c --- /dev/null +++ b/srcpkgs/mozjs128/patches/006-emitter.patch @@ -0,0 +1,67 @@ +From d1d785c169345b81c76213f6dd9be32b4db60294 Mon Sep 17 00:00:00 2001 +From: =?UTF-8?q?Franti=C5=A1ek=20Zatloukal?= +Date: Wed, 15 Jul 2020 08:39:47 +0200 +Subject: [PATCH] Build: allow LOCAL_INCLUDES paths with topsrcdir or topobjdir + +--- + python/mozbuild/mozbuild/frontend/emitter.py | 10 --------- + .../mozbuild/test/frontend/test_emitter.py | 22 ------------------- + 2 files changed, 32 deletions(-) + +diff --git a/python/mozbuild/mozbuild/frontend/emitter.py b/python/mozbuild/mozbuild/frontend/emitter.py +index 44b916e..f2e821d 100644 +--- a/python/mozbuild/mozbuild/frontend/emitter.py ++++ b/python/mozbuild/mozbuild/frontend/emitter.py +@@ -1367,16 +1367,6 @@ class TreeMetadataEmitter(LoggingMixin): + "(resolved to %s)" % (local_include, full_path), + context, + ) +- if ( +- full_path == context.config.topsrcdir +- or full_path == context.config.topobjdir +- ): +- raise SandboxValidationError( +- "Path specified in LOCAL_INCLUDES " +- "(%s) resolves to the topsrcdir or topobjdir (%s), which is " +- "not allowed" % (local_include, full_path), +- context, +- ) + include_obj = LocalInclude(context, local_include) + local_includes.append(include_obj.path.full_path) + yield include_obj +diff --git a/python/mozbuild/mozbuild/test/frontend/test_emitter.py b/python/mozbuild/mozbuild/test/frontend/test_emitter.py +index e53bc5e..c1b9d32 100644 +--- a/python/mozbuild/mozbuild/test/frontend/test_emitter.py ++++ b/python/mozbuild/mozbuild/test/frontend/test_emitter.py +@@ -1098,28 +1098,6 @@ class TestEmitterBasic(unittest.TestCase): + + self.assertEqual(local_includes, expected) + +- def test_local_includes_invalid(self): +- """Test that invalid LOCAL_INCLUDES are properly detected.""" +- reader = self.reader("local_includes-invalid/srcdir") +- +- with six.assertRaisesRegex( +- self, +- SandboxValidationError, +- "Path specified in LOCAL_INCLUDES.*resolves to the " +- "topsrcdir or topobjdir", +- ): +- self.read_topsrcdir(reader) +- +- reader = self.reader("local_includes-invalid/objdir") +- +- with six.assertRaisesRegex( +- self, +- SandboxValidationError, +- "Path specified in LOCAL_INCLUDES.*resolves to the " +- "topsrcdir or topobjdir", +- ): +- self.read_topsrcdir(reader) +- + def test_local_includes_file(self): + """Test that a filename can't be used in LOCAL_INCLUDES.""" + reader = self.reader("local_includes-filename") +-- +2.31.1 + diff --git a/srcpkgs/mozjs128/patches/007-tests-use-native-temporarydirectory.patch b/srcpkgs/mozjs128/patches/007-tests-use-native-temporarydirectory.patch new file mode 100644 index 00000000000..96571ebf825 --- /dev/null +++ b/srcpkgs/mozjs128/patches/007-tests-use-native-temporarydirectory.patch @@ -0,0 +1,65 @@ +From 1af9fdd2124547099eb0cf5a71b513ef5592dbf9 Mon Sep 17 00:00:00 2001 +From: =?UTF-8?q?Franti=C5=A1ek=20Zatloukal?= +Date: Tue, 10 Aug 2021 00:00:50 +0200 +Subject: [PATCH] Tests: Use native TemporaryDirectory + +Without ugly wrapper for Py < 3.2 that doesn't work half of the times... +--- + js/src/jit-test/jit_test.py | 2 +- + js/src/tests/jstests.py | 2 +- + js/src/tests/lib/tempfile.py | 17 +---------------- + 3 files changed, 3 insertions(+), 18 deletions(-) + +diff --git a/js/src/jit-test/jit_test.py b/js/src/jit-test/jit_test.py +index f5d7794..8d443aa 100755 +--- a/js/src/jit-test/jit_test.py ++++ b/js/src/jit-test/jit_test.py +@@ -28,7 +28,7 @@ def add_tests_dir_to_path(): + add_tests_dir_to_path() + + from lib import jittests +-from lib.tempfile import TemporaryDirectory ++from tempfile import TemporaryDirectory + from lib.tests import ( + change_env, + get_cpu_count, +diff --git a/js/src/tests/jstests.py b/js/src/tests/jstests.py +index 6fa2f5f..53ceff6 100755 +--- a/js/src/tests/jstests.py ++++ b/js/src/tests/jstests.py +@@ -27,7 +27,7 @@ from subprocess import call, list2cmdlin + from lib.adaptor import xdr_annotate + from lib.progressbar import ProgressBar + from lib.results import ResultsSink, TestOutput +-from lib.tempfile import TemporaryDirectory ++from tempfile import TemporaryDirectory + from lib.tests import ( + RefTestCase, + change_env, +diff --git a/js/src/tests/lib/tempfile.py b/js/src/tests/lib/tempfile.py +index ecc21c9..f0a1fa3 100644 +--- a/js/src/tests/lib/tempfile.py ++++ b/js/src/tests/lib/tempfile.py +@@ -1,18 +1,4 @@ + # This Source Code Form is subject to the terms of the Mozilla Public + # License, v. 2.0. If a copy of the MPL was not distributed with this + # file, You can obtain one at http://mozilla.org/MPL/2.0/. +-try: +- # Python 3.2 +- from tempfile import TemporaryDirectory +-except ImportError: +- import shutil +- import tempfile +- from contextlib import contextmanager +- +- @contextmanager +- def TemporaryDirectory(*args, **kwds): +- d = tempfile.mkdtemp(*args, **kwds) +- try: +- yield d +- finally: +- shutil.rmtree(d) ++from tempfile import TemporaryDirectory +-- +2.31.1 + diff --git a/srcpkgs/mozjs128/patches/008-init-patch.patch b/srcpkgs/mozjs128/patches/008-init-patch.patch new file mode 100644 index 00000000000..1954a55bf36 --- /dev/null +++ b/srcpkgs/mozjs128/patches/008-init-patch.patch @@ -0,0 +1,28 @@ +From 00414eb67ab0591911167155963b5524fbf2b0c0 Mon Sep 17 00:00:00 2001 +From: =?UTF-8?q?Franti=C5=A1ek=20Zatloukal?= +Date: Mon, 9 Aug 2021 14:38:58 +0200 +Subject: [PATCH] Don't throw InvalidOptionError on invalid options + +--- + python/mozbuild/mozbuild/configure/__init__.py | 5 +---- + 1 file changed, 1 insertion(+), 4 deletions(-) + +diff --git a/python/mozbuild/mozbuild/configure/__init__.py b/python/mozbuild/mozbuild/configure/__init__.py +index f3167f6..c9e1132 100644 +--- a/python/mozbuild/mozbuild/configure/__init__.py ++++ b/python/mozbuild/mozbuild/configure/__init__.py +@@ -553,10 +553,7 @@ class ConfigureSandbox(dict): + for arg in self._helper: + without_value = arg.split("=", 1)[0] + msg = "Unknown option: %s" % without_value +- if self._help: +- self._logger.warning(msg) +- else: +- raise InvalidOptionError(msg) ++ self._logger.warning(msg) + + # Run the execution queue + for func, args in self._execution_queue: +-- +2.31.1 + diff --git a/srcpkgs/mozjs128/patches/009-sloppy-m4-detection.patch b/srcpkgs/mozjs128/patches/009-sloppy-m4-detection.patch new file mode 100644 index 00000000000..10b8b16ea7d --- /dev/null +++ b/srcpkgs/mozjs128/patches/009-sloppy-m4-detection.patch @@ -0,0 +1,29 @@ +From 2d99a7b076578a3394fb9d5be6eb44f9cfebc681 Mon Sep 17 00:00:00 2001 +From: =?UTF-8?q?Franti=C5=A1ek=20Zatloukal?= +Date: Mon, 9 Aug 2021 16:15:37 +0200 +Subject: [PATCH] Remove sloppy m4 detection from bundled autoconf + +--- + build/autoconf/autoconf.sh | 6 ------ + 1 file changed, 6 deletions(-) + +diff --git a/build/autoconf/autoconf.sh b/build/autoconf/autoconf.sh +index ceb8a25..606c74e 100644 +--- a/build/autoconf/autoconf.sh ++++ b/build/autoconf/autoconf.sh +@@ -114,12 +114,6 @@ fi + + # Use the frozen version of Autoconf if available. + r= f= +-# Some non-GNU m4's don't reject the --help option, so give them /dev/null. +-case `$M4 --help < /dev/null 2>&1` in +-*reload-state*) test -r $AC_MACRODIR/autoconf.m4f && { r=--reload f=f; } ;; +-*traditional*) ;; +-*) echo Autoconf requires GNU m4 1.1 or later >&2; rm -f $tmpin; exit 1 ;; +-esac + + $M4 -I$AC_MACRODIR $use_localdir $r autoconf.m4$f $infile > $tmpout || + { rm -f $tmpin $tmpout; exit 2; } +-- +2.31.1 + diff --git a/srcpkgs/mozjs128/patches/011-failing-tests-ppc64-s390x.patch b/srcpkgs/mozjs128/patches/011-failing-tests-ppc64-s390x.patch new file mode 100644 index 00000000000..5c286647325 --- /dev/null +++ b/srcpkgs/mozjs128/patches/011-failing-tests-ppc64-s390x.patch @@ -0,0 +1,36 @@ +From db3a0a25b97377b388532b23e73a10d246f66496 Mon Sep 17 00:00:00 2001 +From: =?UTF-8?q?Franti=C5=A1ek=20Zatloukal?= +Date: Mon, 3 Aug 2020 10:27:00 +0200 +Subject: [PATCH] Skip failing tests on ppc64 and s390x + +ppc64 and s390x: non262/extensions/clone-errors.js +s390x: test262/built-ins/TypedArray/prototype/set/typedarray-arg-set-values-same-buffer-other-type.js +s390x, ppc64 and aarch64: test262/built-ins/Date/UTC/fp-evaluation-order.js +--- + js/src/tests/jstests.list | 9 +++++++++ + 1 file changed, 9 insertions(+) + +diff --git a/js/src/tests/jstests.list b/js/src/tests/jstests.list +index 73ce42f..1797646 100644 +--- a/js/src/tests/jstests.list ++++ b/js/src/tests/jstests.list +@@ -53,6 +53,15 @@ skip-if(!this.hasOwnProperty("Intl")) include test262/intl402/jstests.list + skip-if(!this.hasOwnProperty("Atomics")) include test262/built-ins/Atomics/jstests.list + skip-if(!this.hasOwnProperty("SharedArrayBuffer")) include test262/built-ins/SharedArrayBuffer/jstests.list + ++# Crashes on s390x and ppc64, avoid it ++skip-if(xulRuntime.XPCOMABI.match(/s390x|ppc64-/)) script non262/extensions/clone-errors.js ++ ++# Crashes on s390x, ppc64, aarch64 ++skip-if(xulRuntime.XPCOMABI.match(/s390x|aarch64|ppc64-/)) script test262/built-ins/Date/UTC/fp-evaluation-order.js ++ ++# Crashes on s390x, avoid it ++skip-if(xulRuntime.XPCOMABI.match(/s390x/)) script test262/built-ins/TypedArray/prototype/set/typedarray-arg-set-values-same-buffer-other-type.js ++ + ##################################### + # Test262 tests disabled on browser # + ##################################### +-- +2.31.1 + + diff --git a/srcpkgs/mozjs128/patches/013-disable-spidermonkey-jslint.patch b/srcpkgs/mozjs128/patches/013-disable-spidermonkey-jslint.patch new file mode 100644 index 00000000000..93e8c83f933 --- /dev/null +++ b/srcpkgs/mozjs128/patches/013-disable-spidermonkey-jslint.patch @@ -0,0 +1,26 @@ +commit 34d8f3fb025e930450ce44f7aac501da4c2adc9c +Author: Daniel Kolesa +Date: Sun Jan 23 21:09:42 2022 +0100 + + disable spidermonkey jslint + +diff --git a/js/src/build/moz.build b/js/src/build/moz.build +index 55c66b97..243f7db2 100644 +--- a/js/src/build/moz.build ++++ b/js/src/build/moz.build +@@ -97,15 +97,3 @@ NO_EXPAND_LIBS = True + + DIST_INSTALL = True + +-# Run SpiderMonkey style checker after linking the static library. This avoids +-# running the script for no-op builds. +-GeneratedFile( +- "spidermonkey_checks", +- script="/config/run_spidermonkey_checks.py", +- inputs=[ +- "!%sjs_static.%s" % (CONFIG["LIB_PREFIX"], CONFIG["LIB_SUFFIX"]), +- "/config/check_spidermonkey_style.py", +- "/config/check_macroassembler_style.py", +- "/config/check_js_opcode.py", +- ], +-) diff --git a/srcpkgs/mozjs128/patches/014-rust-target.patch b/srcpkgs/mozjs128/patches/014-rust-target.patch new file mode 100644 index 00000000000..4d8918a2a54 --- /dev/null +++ b/srcpkgs/mozjs128/patches/014-rust-target.patch @@ -0,0 +1,28 @@ +commit 34b3ac3195a40757bc5f51a1db5a47a4b18c68b5 +Author: Daniel Kolesa +Date: Sun Jan 23 21:13:38 2022 +0100 + + bypass rust triplet checks and just force ours + +diff --git a/build/moz.configure/rust.configure b/build/moz.configure/rust.configure +index cd77d72b..0c03cab7 100644 +--- a/build/moz.configure/rust.configure ++++ b/build/moz.configure/rust.configure +@@ -261,7 +261,7 @@ def rust_supported_targets(rustc): + data.setdefault(key, []).append(namespace(rust_target=t, target=info)) + return data + +- ++@imports("os") + def detect_rustc_target( + host_or_target, compiler_info, arm_target, rust_supported_targets + ): +@@ -383,7 +383,7 @@ def detect_rustc_target( + + return None + +- rustc_target = find_candidate(candidates) ++ rustc_target = os.environ["RUST_TARGET"] + + if rustc_target is None: + die("Don't know how to translate {} for rustc".format(host_or_target.alias)) diff --git a/srcpkgs/mozjs128/patches/015-drop-rustc-validation.patch b/srcpkgs/mozjs128/patches/015-drop-rustc-validation.patch new file mode 100644 index 00000000000..e2b340cd060 --- /dev/null +++ b/srcpkgs/mozjs128/patches/015-drop-rustc-validation.patch @@ -0,0 +1,80 @@ +drop some rust compiler validation + +--- a/build/moz.configure/rust.configure ++++ b/build/moz.configure/rust.configure +@@ -91,9 +91,6 @@ def unwrap_rustup(prog, name): + return unwrap + + +-rustc = unwrap_rustup(rustc, "rustc") +-cargo = unwrap_rustup(cargo, "cargo") +- + + set_config("CARGO", cargo) + set_config("RUSTC", rustc) +@@ -411,35 +408,6 @@ def assert_rust_compile(host_or_target, rustc_target, rustc): + + os.write(in_fd, ensure_binary(source)) + os.close(in_fd) +- +- cmd = [ +- rustc, +- "--crate-type", +- "staticlib", +- target_arg, +- "-o", +- out_path, +- in_path, +- ] +- +- def failed(): +- die( +- dedent( +- """\ +- Cannot compile for {} with {} +- The target may be unsupported, or you may not have +- a rust std library for that target installed. Try: +- +- rustup target add {} +- """.format( +- host_or_target.alias, rustc, rustc_target +- ) +- ) +- ) +- +- check_cmd_output(*cmd, onerror=failed) +- if not os.path.exists(out_path) or os.path.getsize(out_path) == 0: +- failed() + finally: + os.remove(in_path) + os.remove(out_path) +@@ -462,29 +430,6 @@ def rust_host_triple( + rustc_target = detect_rustc_target( + host, compiler_info, arm_target, rust_supported_targets + ) +- if rustc_target != rustc_host: +- if host.alias == rustc_target: +- configure_host = host.alias +- else: +- configure_host = "{}/{}".format(host.alias, rustc_target) +- die( +- dedent( +- """\ +- The rust compiler host ({rustc}) is not suitable for the configure host ({configure}). +- +- You can solve this by: +- * Set your configure host to match the rust compiler host by editing your +- mozconfig and adding "ac_add_options --host={rustc}". +- * Or, install the rust toolchain for {configure}, if supported, by running +- "rustup default stable-{rustc_target}" +- """.format( +- rustc=rustc_host, +- configure=configure_host, +- rustc_target=rustc_target, +- ) +- ) +- ) +- assert_rust_compile(host, rustc_target, rustc) + return rustc_target + + diff --git a/srcpkgs/mozjs128/patches/017-no-lto-readelf.patch b/srcpkgs/mozjs128/patches/017-no-lto-readelf.patch new file mode 100644 index 00000000000..e618dd2c1d0 --- /dev/null +++ b/srcpkgs/mozjs128/patches/017-no-lto-readelf.patch @@ -0,0 +1,35 @@ +commit 1cc729c5221d0ce4c80786ccdcb2de4a6ca382b6 +Author: Daniel Kolesa +Date: Sun Jan 23 21:55:43 2022 +0100 + + drop some library checks + + This calls readelf and won't work with LTO'd setups. + +diff --git a/config/makefiles/rust.mk b/config/makefiles/rust.mk +index 401c2933..ade4f1da 100644 +--- a/config/makefiles/rust.mk ++++ b/config/makefiles/rust.mk +@@ -497,22 +497,6 @@ force-cargo-library-build: + $(call BUILDSTATUS,START_Rust $(notdir $(RUST_LIBRARY_FILE))) + $(call CARGO_BUILD) --lib $(cargo_target_flag) $(rust_features_flag) -- $(cargo_rustc_flags) + $(call BUILDSTATUS,END_Rust $(notdir $(RUST_LIBRARY_FILE))) +-# When we are building in --enable-release mode; we add an additional check to confirm +-# that we are not importing any networking-related functions in rust code. This reduces +-# the chance of proxy bypasses originating from rust code. +-# The check only works when rust code is built with -Clto but without MOZ_LTO_RUST_CROSS. +-# Sanitizers and sancov also fail because compiler-rt hooks network functions. +-ifndef MOZ_PROFILE_GENERATE +-ifeq ($(OS_ARCH), Linux) +-ifeq (,$(rustflags_sancov)$(MOZ_ASAN)$(MOZ_TSAN)$(MOZ_UBSAN)) +-ifndef MOZ_LTO_RUST_CROSS +-ifneq (,$(filter -Clto,$(cargo_rustc_flags))) +- $(call py_action,check_binary $(@F),--networking $(RUST_LIBRARY_FILE)) +-endif +-endif +-endif +-endif +-endif + + $(eval $(call make_cargo_rule,$(RUST_LIBRARY_FILE),force-cargo-library-build)) + diff --git a/srcpkgs/mozjs128/patches/MOZ_NO_RUST_LTO.patch b/srcpkgs/mozjs128/patches/MOZ_NO_RUST_LTO.patch new file mode 100644 index 00000000000..4a9b0b42a57 --- /dev/null +++ b/srcpkgs/mozjs128/patches/MOZ_NO_RUST_LTO.patch @@ -0,0 +1,18 @@ +--- a/config/makefiles/rust.mk ++++ b/config/makefiles/rust.mk +@@ -64,6 +64,7 @@ endif + # These flags are passed via `cargo rustc` and only apply to the final rustc + # invocation (i.e., only the top-level crate, not its dependencies). + cargo_rustc_flags = $(CARGO_RUSTCFLAGS) ++ifneq (1,$(MOZ_NO_RUST_LTO)) + ifndef DEVELOPER_OPTIONS + ifndef MOZ_DEBUG_RUST + # Enable link-time optimization for release builds, but not when linking +@@ -77,6 +78,7 @@ RUSTFLAGS += -Cembed-bitcode=yes + endif + endif + endif ++endif + + ifdef CARGO_INCREMENTAL + export CARGO_INCREMENTAL diff --git a/srcpkgs/mozjs128/patches/armv6l-isb.patch b/srcpkgs/mozjs128/patches/armv6l-isb.patch new file mode 100644 index 00000000000..1a7f3e45ee4 --- /dev/null +++ b/srcpkgs/mozjs128/patches/armv6l-isb.patch @@ -0,0 +1,16 @@ +diff -rup Architecture-arm.cpp.orig Architecture-arm.cpp +--- a/js/src/jit/arm/Architecture-arm.cpp ++++ b/js/src/jit/arm/Architecture-arm.cpp +@@ -531,7 +531,11 @@ void FlushExecutionContext() { + #ifndef JS_SIMULATOR_ARM + // Ensure that any instructions already in the pipeline are discarded and + // reloaded from the icache. +- asm volatile("isb\n" : : : "memory"); ++# if defined(__ARM_ARCH_7__) || defined(__ARM_ARCH_7A__) ++ asm volatile("isb\n" : : : "memory"); ++# else ++ asm volatile("mcr p15, 0, %0, c7, c5, 4" : : "r" (0) : "memory"); ++# endif + #else + // We assume the icache flushing routines on other platforms take care of this + #endif diff --git a/srcpkgs/mozjs128/patches/d535cd70e034b4ccdccf8b7d9243ffa931a46c78.patch b/srcpkgs/mozjs128/patches/d535cd70e034b4ccdccf8b7d9243ffa931a46c78.patch new file mode 100644 index 00000000000..e66f6fb66e7 --- /dev/null +++ b/srcpkgs/mozjs128/patches/d535cd70e034b4ccdccf8b7d9243ffa931a46c78.patch @@ -0,0 +1,100 @@ +From d535cd70e034b4ccdccf8b7d9243ffa931a46c78 Mon Sep 17 00:00:00 2001 +From: Rob Wu +Date: Tue, 5 Nov 2024 21:24:20 +0000 +Subject: [PATCH] Bug 1926140 - Replace pipes imports r=jmaher + +pipes does not exist in Python 3.11 any more + +Differential Revision: https://phabricator.services.mozilla.com/D227964 +--- + js/src/tests/lib/results.py | 4 ++-- + testing/mozbase/mozdevice/mozdevice/adb.py | 3 --- + testing/web-platform/tests/tools/pytest.ini | 2 -- + testing/xpcshell/runxpcshelltests.py | 6 +++--- + 4 files changed, 5 insertions(+), 10 deletions(-) + +diff --git a/js/src/tests/lib/results.py b/js/src/tests/lib/results.py +index 42f8d7c163bce..1d18b9eb69de3 100644 +--- a/js/src/tests/lib/results.py ++++ b/js/src/tests/lib/results.py +@@ -1,6 +1,6 @@ + import json +-import pipes + import re ++import shlex + + from .progressbar import NullProgressBar, ProgressBar + from .structuredlog import TestLogger +@@ -9,7 +9,7 @@ + + + def escape_cmdline(args): +- return " ".join([pipes.quote(a) for a in args]) ++ return " ".join([shlex.quote(a) for a in args]) + + + class TestOutput: +diff --git a/testing/mozbase/mozdevice/mozdevice/adb.py b/testing/mozbase/mozdevice/mozdevice/adb.py +index 0495e863aa679..d06f40e4915b5 100644 +--- a/testing/mozbase/mozdevice/mozdevice/adb.py ++++ b/testing/mozbase/mozdevice/mozdevice/adb.py +@@ -4,7 +4,6 @@ + + import io + import os +-import pipes + import posixpath + import re + import shlex +@@ -1293,8 +1292,6 @@ def _quote(arg): + """Utility function to return quoted version of command argument.""" + if hasattr(shlex, "quote"): + quote = shlex.quote +- elif hasattr(pipes, "quote"): +- quote = pipes.quote + else: + + def quote(arg): +diff --git a/testing/web-platform/tests/tools/pytest.ini b/testing/web-platform/tests/tools/pytest.ini +index 650d07caf3a67..3f3d0983ab183 100644 +--- a/testing/web-platform/tests/tools/pytest.ini ++++ b/testing/web-platform/tests/tools/pytest.ini +@@ -20,8 +20,6 @@ filterwarnings = + ignore:This method will be removed in .*\.\s+Use 'parser\.read_file\(\)' instead\.:DeprecationWarning:mozversion + # ignore mozversion not cleanly closing .ini files + ignore:unclosed file.*\.ini:ResourceWarning:mozversion +- # mozdevice uses pipes module +- ignore:'pipes' is deprecated and slated for removal in Python 3:DeprecationWarning + # mozrunner uses telnetlib module + ignore:'telnetlib' is deprecated and slated for removal in Python 3:DeprecationWarning + # https://github.com/web-platform-tests/wpt/issues/39366 +diff --git a/testing/xpcshell/runxpcshelltests.py b/testing/xpcshell/runxpcshelltests.py +index 77b26a39aa12c..45ca22ac0430a 100755 +--- a/testing/xpcshell/runxpcshelltests.py ++++ b/testing/xpcshell/runxpcshelltests.py +@@ -7,10 +7,10 @@ + import copy + import json + import os +-import pipes + import platform + import random + import re ++import shlex + import shutil + import signal + import subprocess +@@ -372,11 +372,11 @@ def logCommand(self, name, completeCmd, testdir): + ) + self.log.info("%s | environment: %s" % (name, list(changedEnv))) + shell_command_tokens = [ +- pipes.quote(tok) for tok in list(changedEnv) + completeCmd ++ shlex.quote(tok) for tok in list(changedEnv) + completeCmd + ] + self.log.info( + "%s | as shell command: (cd %s; %s)" +- % (name, pipes.quote(testdir), " ".join(shell_command_tokens)) ++ % (name, shlex.quote(testdir), " ".join(shell_command_tokens)) + ) + + def killTimeout(self, proc): diff --git a/srcpkgs/mozjs128/patches/fix-build-ppc32.patch b/srcpkgs/mozjs128/patches/fix-build-ppc32.patch new file mode 100644 index 00000000000..f9f8e0cd7ac --- /dev/null +++ b/srcpkgs/mozjs128/patches/fix-build-ppc32.patch @@ -0,0 +1,18 @@ +From 62780b31095fcd37a5d9218d0393d552bc44149f Mon Sep 17 00:00:00 2001 +From: q66 +Date: Mon Jun 13 14:01:59 2022 +0200 +Subject: fix ftbfs on powerpc32 + +diff --git a/js/src/wasm/WasmDebugFrame.h b/js/src/wasm/WasmDebugFrame.h +index 47652e9..02a13559 100644 +--- a/js/src/wasm/WasmDebugFrame.h ++++ b/js/src/wasm/WasmDebugFrame.h +@@ -112,7 +112,7 @@ class DebugFrame { + + // Avoid -Wunused-private-field warnings. + protected: +-#if defined(JS_CODEGEN_ARM) || defined(JS_CODEGEN_X86) || defined(__wasi__) ++#if defined(JS_CODEGEN_ARM) || defined(JS_CODEGEN_X86) || defined(__wasi__) || (defined(__powerpc__) && !defined(__powerpc64__)) + // See alignmentStaticAsserts(). For ARM32 and X86 DebugFrame is only + // 4-byte aligned, so we add another word to get up to 8-byte + // alignment. diff --git a/srcpkgs/mozjs128/patches/fix-i386-fdlibm.patch b/srcpkgs/mozjs128/patches/fix-i386-fdlibm.patch new file mode 100644 index 00000000000..831e5e03678 --- /dev/null +++ b/srcpkgs/mozjs128/patches/fix-i386-fdlibm.patch @@ -0,0 +1,18 @@ +# error: typedef redefinition with different types ('__double_t' (aka 'double') vs 'long double') +# https://bugzilla.mozilla.org/show_bug.cgi?id=1729459 + +--- a/modules/fdlibm/src/math_private.h ++++ b/modules/fdlibm/src/math_private.h +@@ -30,7 +30,12 @@ + * Adapted from https://github.com/freebsd/freebsd-src/search?q=__double_t + */ + ++#if defined(__linux__) && defined(__i386__) ++// rely on glibc's double_t ++typedef long double __double_t; ++#else + typedef double __double_t; ++#endif + typedef __double_t double_t; + + /* diff --git a/srcpkgs/mozjs128/template b/srcpkgs/mozjs128/template new file mode 100644 index 00000000000..94b911372bd --- /dev/null +++ b/srcpkgs/mozjs128/template @@ -0,0 +1,84 @@ +# Template file for 'mozjs128' +pkgname=mozjs128 +version=128.7.0 +revision=1 +build_wrksrc=js/src +build_style=gnu-configure +build_helper=rust +make_check_target=check-jit-test +configure_args="--disable-jemalloc --disable-strip --disable-tests \ + --disable-optimize --disable-debug --enable-ctypes --enable-readline \ + --enable-shared-js --enable-system-ffi --with-intl-api --with-system-icu \ + --with-system-nspr --with-system-zlib --enable-hardening --enable-release" +hostmakedepends="make pkg-config python3 cbindgen perl m4 + rust cargo llvm19 clang19" +makedepends="icu-devel libffi-devel nspr-devel python3-devel readline-devel + zlib-devel rust-std" +checkdepends="python3" +short_desc="SpiderMonkey JavaScript interpreter and library (128.x)" +maintainer="oreo639 " +license="MPL-2.0" +homepage="https://spidermonkey.dev" +distfiles="${MOZILLA_SITE}/firefox/releases/${version}esr/source/firefox-${version}esr.source.tar.xz" +checksum=e0a7bf4eddfa33cbc8797d68ecea8fb4e6404ca197d3b2242cbc8daed03794f7 + +LDFLAGS="-Wl,-z,stack-size=1048576" + +pre_configure() { + if [ "$CROSS_BUILD" ]; then + configure_args+=" --host=${XBPS_TRIPLET} --target=${XBPS_CROSS_TRIPLET} --enable-linker=bfd" + fi + export M4=m4 + export AWK=awk + export AC_MACRODIR=${wrksrc}/build/autoconf +} + +post_install() { + # Remove unneeded static library + rm -f "${DESTDIR}"/usr/lib/*.ajs + + # it has correct soname but not the right file name + mv "${DESTDIR}"/usr/lib/libmozjs-${version%%.*}.so \ + "${DESTDIR}"/usr/lib/libmozjs-${version%%.*}.so.0 + ln -rs "${DESTDIR}"/usr/lib/libmozjs-${version%%.*}.so.0 \ + "${DESTDIR}"/usr/lib/libmozjs-${version%%.*}.so +} + +pre_check() { + export JITTEST_EXTRA_ARGS="--timeout 600" + if [ "$XBPS_WORDSIZE" = 32 ]; then + vsed -i jit-test/tests/basic/bug653153.js -e s/65536/65568/g + vsed -i jit-test/tests/basic/bug653153.js -e s/65537/65569/g + vsed -i jit-test/tests/bug1782468-ptrdiff-veclen.js -e 's/getBuildConfiguration("pointer-byte-size") == 4/false/g' + fi + if [ "$XBPS_TARGET_MACHINE" = i686 ]; then + export JITTEST_EXTRA_ARGS="${JITTEST_EXTRA_ARGS} \ + -x basic/fdlibm-for-sin-cos-tan-argument.js \ + -x gc/gcparam.js \ + -x ion/dce-with-rinstructions.js \ + -x sunspider/check-3d-cube.js \ + -x sunspider/check-3d-raytrace.js \ + -x sunspider/check-access-nbody.js \ + -x wasm \ + -x resist-fingerprinting/math-fdlibm-sincostan-asm.js \ + -x resist-fingerprinting/math-fdlibm-sincostan.js \ + " + fi + if [ "$XBPS_LIBC" = musl ]; then + export JITTEST_EXTRA_ARGS="${JITTEST_EXTRA_ARGS} \ + -x sunspider/check-date-format-tofte.js \ + -x resist-fingerprinting/math-fdlibm-sincostan.js \ + " + fi +} + +mozjs128-devel_package() { + depends="nspr-devel ${sourcepkg}>=${version}_${revision}" + short_desc+=" - development files" + pkg_install() { + vmove usr/bin + vmove usr/include + vmove "usr/lib/*.so" + vmove usr/lib/pkgconfig + } +} diff --git a/srcpkgs/mozjs128/update b/srcpkgs/mozjs128/update new file mode 100644 index 00000000000..f942fe4f0fc --- /dev/null +++ b/srcpkgs/mozjs128/update @@ -0,0 +1,2 @@ +site="${MOZILLA_SITE}/firefox/releases/" +pattern="releases/\K${version%%.*}.*(?=esr/\")"