diff options
author | B Stack <bgstack15@gmail.com> | 2018-09-14 11:39:42 -0400 |
---|---|---|
committer | B Stack <bgstack15@gmail.com> | 2018-09-14 11:39:42 -0400 |
commit | 4ecb6db04ce862ec1b8a88db5daef0eda7c7a05d (patch) | |
tree | 512b8eae0c2ef46e9debfe96af748b308deb27c4 /waterfox/waterfox.spec | |
parent | Merge branch 'add-ublock' into 'master' (diff) | |
download | stackrpms-4ecb6db04ce862ec1b8a88db5daef0eda7c7a05d.tar.gz stackrpms-4ecb6db04ce862ec1b8a88db5daef0eda7c7a05d.tar.bz2 stackrpms-4ecb6db04ce862ec1b8a88db5daef0eda7c7a05d.zip |
bring in chinforpms/waterfox
Diffstat (limited to 'waterfox/waterfox.spec')
-rw-r--r-- | waterfox/waterfox.spec | 982 |
1 files changed, 982 insertions, 0 deletions
diff --git a/waterfox/waterfox.spec b/waterfox/waterfox.spec new file mode 100644 index 0000000..441d647 --- /dev/null +++ b/waterfox/waterfox.spec @@ -0,0 +1,982 @@ +%global commit 2294d4556bf76a6293275a17dbf9ef5fd187459e +%global shortcommit %(c=%{commit}; echo ${c:0:7}) +%global date 20180908 +%global with_snapshot 1 + +%global freebsd_rev 478244 +%global freebsd_root %{name}-FreeBSD-patches-r%{freebsd_rev} + +%if 0%{?with_snapshot} +%global gver .%{date}git%{shortcommit} +%endif + +# Build with only clang? +%global with_clang 0 + +# Use ALSA backend? +%global alsa_backend 1 + +# Use system nspr/nss? +%global system_nss 1 + +# Use system hunspell? +%global system_hunspell 1 + +# Use system libevent? +%global system_libevent 1 + +# Use system sqlite? +%global system_sqlite 1 + +%global system_ffi 1 + +# Use system cairo? +%global system_cairo 0 + +# Use system graphite2/harfbuzz? +%global system_harfbuzz 1 + +# Use system libvpx? +%global system_libvpx 1 + +# Use system webp? +%global system_webp 1 + +# Use system libvpx? +%global system_vorbis 1 + +# Use system libicu? +%global system_libicu 0 + +# Big endian platforms +%ifarch ppc64 s390x +# Javascript Intl API is not supported on big endian platforms right now: +# https://bugzilla.mozilla.org/show_bug.cgi?id=1322212 +%global big_endian 1 +%endif + +# Hardened build? +%global hardened_build 1 + +%global system_jpeg 1 + +%ifarch %{ix86} x86_64 +%global run_tests 0 +%else +%global run_tests 0 +%endif + +# Build as a debug package? +%global debug_build 0 + +%global default_bookmarks_file %{_datadir}/bookmarks/default-bookmarks.html +%global waterfox_app_id \{ec8030f7-c20a-464f-9b0e-13a3a9e97384\} +# Minimal required versions +%global cairo_version 1.13.1 +%global freetype_version 2.1.9 +%if %{?system_harfbuzz} +%global graphite2_version 1.3.10 +%global harfbuzz_version 1.4.7 +%endif +%if %{?system_libevent} +%global libevent_version 2.1.8 +%endif +%global libnotify_version 0.7.0 +%if %{?system_libvpx} +%global libvpx_version 1.4.0 +%endif +%if %{?system_webp} +%global webp_version 1.0.0 +%endif +%if %{?system_vorbis} +%global ogg_version 1.3.3 +%global vorbis_version 1.3.5 +%endif + +%if %{?system_nss} +%global nspr_version 4.17.0 +# NSS/NSPR quite often ends in build override, so as requirement the version +# we're building against could bring us some broken dependencies from time to time. +%global nspr_build_version %{nspr_version} +%global nss_version 3.34 +%global nss_build_version %{nss_version} +%endif + +%if %{?system_sqlite} +%global sqlite_version 3.8.4.2 +# The actual sqlite version (see #480989): +%global sqlite_build_version %(pkg-config --silence-errors --modversion sqlite3 2>/dev/null || echo 65536) +%endif + +%global mozappdir %{_libdir}/%{name} +%global mozappdirdev %{_libdir}/%{name}-devel-%{version} +%global langpackdir %{mozappdir}/langpacks + +%global build_langpacks 1 + +Summary: Waterfox Web browser +Name: waterfox +Version: 56.2.2 +Release: 4%{?gver}%{?dist} +URL: https://www.waterfoxproject.org +License: MPLv1.1 or GPLv2+ or LGPLv2+ +%if 0%{?with_snapshot} +Source0: https://github.com/MrAlex94/%{name}/archive/%{commit}.tar.gz#/%{name}-%{shortcommit}.tar.gz +%else +Source0: https://github.com/MrAlex94/%{name}/archive/%{version}.tar.gz#/%{name}-%{version}.tar.gz +%endif + +# FreeBSD patches +# https://www.freshports.org/www/waterfox +# rev=revision ./waterfox-FreeBSD-patches-snapshot.sh +Source600: http://dl.bintray.com/phantomx/tarballs/%{freebsd_root}.tar.xz + +Source10: waterfox-mozconfig +Source12: waterfox-chinfo-default-prefs.js +Source20: waterfox.desktop +Source21: waterfox.sh.in +Source23: waterfox.1 +Source26: distribution.ini + +# Build patches +Patch0: firefox-install-dir.patch +Patch3: mozilla-build-arm.patch +# https://bugzilla.redhat.com/show_bug.cgi?id=814879#c3 +Patch18: xulrunner-24.0-jemalloc-ppc.patch +Patch20: firefox-build-prbool.patch +Patch25: rhbz-1219542-s390-build.patch +Patch26: build-icu-big-endian.patch +Patch27: mozilla-1335250.patch +Patch30: fedora-build.patch +Patch31: build-ppc64-s390x-curl.patch +Patch32: build-rust-ppc64le.patch +Patch35: build-ppc-jit.patch +Patch36: build-missing-xlocale-h.patch +# Always feel lucky for unsupported platforms: +# https://bugzilla.mozilla.org/show_bug.cgi?id=1347128 +Patch37: build-jit-atomic-always-lucky.patch +# Fixing missing cacheFlush when JS_CODEGEN_NONE is used (s390x) +Patch38: build-cacheFlush-missing.patch + +# Fedora specific patches +Patch215: firefox-enable-addons.patch +Patch219: rhbz-1173156.patch +Patch221: firefox-fedora-ua.patch +Patch224: mozilla-1170092.patch +Patch225: mozilla-1005640-accept-lang.patch +#ARM run-time patch +Patch226: rhbz-1354671.patch +Patch230: rhbz-1497932.patch + +# Firefox upstream patches +Patch402: mozilla-1196777.patch +Patch406: mozilla-256180.patch +Patch413: mozilla-1353817.patch +Patch414: mozilla-1435695.patch +Patch415: Bug-1238661---fix-mozillaSignalTrampoline-to-work-.patch +Patch416: bug1375074-save-restore-x28.patch +Patch417: mozilla-1436242.patch + +# Upstream updates + +%global wf_url https://github.com/MrAlex94/Waterfox +#Patch???: %%{wf_url}/commit/commit.patch#/wf-commit.patch +Patch490: %{wf_url}/pull/547.patch#/wf-pull-547.patch + +# Debian patches +Patch500: mozilla-440908.patch + +# Chinforinfula patches +Patch700: %{name}-nolangpacks.patch +Patch701: %{name}-waterfoxdir.patch + +%if %{?system_nss} +BuildRequires: pkgconfig(nspr) >= %{nspr_version} +BuildRequires: pkgconfig(nss) >= %{nss_version} +BuildRequires: nss-static >= %{nss_version} +%endif +%if %{?system_cairo} +BuildRequires: pkgconfig(cairo) >= %{cairo_version} +%endif +BuildRequires: pkgconfig(libpng) +%if %{?system_jpeg} +BuildRequires: libjpeg-devel +%endif +BuildRequires: zip +BuildRequires: bzip2-devel +BuildRequires: pkgconfig(zlib) +BuildRequires: pkgconfig(libIDL-2.0) +BuildRequires: pkgconfig(gtk+-3.0) +BuildRequires: pkgconfig(gtk+-2.0) +BuildRequires: pkgconfig(krb5) +BuildRequires: pkgconfig(pango) +BuildRequires: pkgconfig(freetype2) >= %{freetype_version} +%if %{?system_harfbuzz} +BuildRequires: pkgconfig(graphite2) >= %{graphite2_version} +BuildRequires: pkgconfig(harfbuzz) >= %{harfbuzz_version} +%endif +BuildRequires: pkgconfig(xt) +BuildRequires: pkgconfig(xrender) +%if %{?system_hunspell} +BuildRequires: pkgconfig(hunspell) +%endif +%if %{?system_libevent} +BuildRequires: pkgconfig(libevent) >= %{libevent_version} +%endif +BuildRequires: pkgconfig(libstartup-notification-1.0) +%if %{?alsa_backend} +BuildRequires: pkgconfig(alsa) +%endif +BuildRequires: pkgconfig(libnotify) >= %{libnotify_version} +BuildRequires: pkgconfig(dri) +BuildRequires: pkgconfig(libcurl) +BuildRequires: dbus-glib-devel +BuildRequires: pkgconfig(libv4l2) +%if %{?system_libvpx} +BuildRequires: pkgconfig(vpx) >= %{libvpx_version} +%endif +%if %{?system_webp} +BuildRequires: pkgconfig(libwebp) >= %{webp_version} +%endif +%if %{?system_vorbis} +BuildRequires: pkgconfig(ogg) >= %{ogg_version} +BuildRequires: pkgconfig(vorbis) >= %{vorbis_version} +%endif +BuildRequires: autoconf213 +BuildRequires: pkgconfig(libpulse) +BuildRequires: pkgconfig(icu-i18n) +BuildRequires: yasm +BuildRequires: llvm +BuildRequires: llvm-devel +BuildRequires: clang +BuildRequires: clang-libs +%if !0%{?with_clang} +BuildRequires: gcc-c++ +%endif +BuildRequires: patchutils + +Requires: mozilla-filesystem +Requires: waterfox-filesystem +Requires: p11-kit-trust +%if %{?system_nss} +Requires: nspr >= %{nspr_build_version} +Requires: nss >= %{nss_build_version} +%endif +BuildRequires: python2-devel + +BuildRequires: nss-devel >= 3.29.1-2.1 +Requires: nss >= 3.29.1-2.1 + +BuildRequires: desktop-file-utils +BuildRequires: system-bookmarks +%if %{?system_sqlite} +BuildRequires: pkgconfig(sqlite3) >= %{sqlite_version} +Requires: sqlite >= %{sqlite_build_version} +%endif + +%if %{?system_ffi} +BuildRequires: pkgconfig(libffi) +%endif + +%if %{?run_tests} +BuildRequires: xorg-x11-server-Xvfb +%endif +BuildRequires: rust +BuildRequires: cargo + +Obsoletes: mozilla <= 37:1.7.13 +Provides: webclient + +%description +Waterfox is an open-source web browser, specialised modification of the Mozilla +platform, designed for privacy and user choice in mind. + +%if %{run_tests} +%global testsuite_pkg_name mozilla-%{name}-testresults +%package -n %{testsuite_pkg_name} +Summary: Results of testsuite +%description -n %{testsuite_pkg_name} +This package contains results of tests executed during build. +%files -n %{testsuite_pkg_name} +/test_results +%endif + +#--------------------------------------------------------------------- + +%prep +%if 0%{?with_snapshot} +%setup -q -n Waterfox-%{commit} -a 600 +%else +%setup -q -n Waterfox-%{version} -a 600 +%endif + +%if %{build_langpacks} + mkdir waterfox-langpacks + mv browser/extensions/langpack-*.xpi waterfox-langpacks/ +%else + rm -f browser/extensions/langpack-*.xpi +%endif + +# Build patches, can't change backup suffix from default because during build +# there is a compare of config and js/config directories and .orig suffix is +# ignored during this compare. +%patch0 -p1 + + +%patch18 -p1 -b .jemalloc-ppc +%patch20 -p1 -b .prbool +%ifarch s390 +%patch25 -p1 -b .rhbz-1219542-s390 +%endif +%patch30 -p1 -b .fedora-build +%patch31 -p1 -b .ppc64-s390x-curl +%patch32 -p1 -b .rust-ppc64le +%ifarch ppc ppc64 ppc64le +%patch35 -p1 -b .ppc-jit +%endif +%patch37 -p1 -b .jit-atomic-lucky + +%patch3 -p1 -b .arm + +# For branding specific patches. + +# Fedora patches +%patch215 -p1 -b .addons +%patch219 -p2 -b .rhbz-1173156 +%patch221 -p2 -b .fedora-ua +%patch224 -p1 -b .1170092 +%patch225 -p1 -b .1005640-accept-lang +#ARM run-time patch +%ifarch aarch64 +%patch226 -p1 -b .1354671 +%endif +%patch230 -p1 -b .1497932 + +%patch402 -p1 -b .1196777 +%patch406 -p1 -b .256180 +%patch413 -p1 -b .1353817 +%patch414 -p1 -b .1435695 +%ifarch %{arm} +%patch415 -p1 -b .mozilla-1238661 +%endif +%patch416 -p1 -b .bug1375074-save-restore-x28 +%patch417 -p1 -b .mozilla-1436242 + +%patch490 -p1 + +# Debian extension patch +%patch500 -p1 -b .440908 + +# Prepare FreeBSD patches +mkdir _patches +cp -p %{freebsd_root}/patch-{bug,z-bug,revert-bug}* _patches/ + +filterdiff -x dom/svg/crashtests/crashtests.list %{freebsd_root}/patch-bug1343147 \ + > _patches/patch-bug1343147 +filterdiff -x dom/security/test/csp/mochitest.ini %{freebsd_root}/patch-bug1381761 \ + > _patches/patch-bug1381761 + +for i in 1404057 1404324 1404180 1405878 ;do + filterdiff \ + -x layout/style/crashtests/crashtests.list \ + -x layout/reftests/bugs/reftest.list \ + %{freebsd_root}/patch-bug${i} > _patches/patch-bug${i} +done + +# 1: unneeded +# 2: no apply +# 3: uncertain +for i in \ + 702179 991253 1021761 1144632 1288587 1452576 1425930 1469914 1469309 1470260 1472925 \ + 1388744 1413143 \ + 1447519 +do + rm -f _patches/patch-bug${i} +done + +%if 0%{?fedora} < 28 + rm -f _patches/patch-bug730495 +%endif + +patchcommand='patch -p0 -s -i' + +for i in _patches/patch-{bug{??????,???????},revert-bug*,z-*} ;do + ${patchcommand} ${i} +done + +# Install langpacks other way +%patch700 -p1 -b .nolangpacks +%patch701 -p1 -b .waterfoxdir + +# Patch for big endian platforms only +%if 0%{?big_endian} +%patch26 -p1 -b .icu +%patch36 -p2 -b .xlocale +%endif + +rm -f .mozconfig +cp %{SOURCE10} .mozconfig + +%if 0%{?with_clang} +echo 'export CC=clang' >> .mozconfig +echo 'export CXX=clang++' >> .mozconfig +%endif + +%if %{?system_nss} +echo "ac_add_options --with-system-nspr" >> .mozconfig +echo "ac_add_options --with-system-nss" >> .mozconfig +%else +echo "ac_add_options --without-system-nspr" >> .mozconfig +echo "ac_add_options --without-system-nss" >> .mozconfig +%endif + +%if %{?system_sqlite} +echo "ac_add_options --enable-system-sqlite" >> .mozconfig +%else +echo "ac_add_options --disable-system-sqlite" >> .mozconfig +%endif + +%if %{?system_cairo} +echo "ac_add_options --enable-system-cairo" >> .mozconfig +%else +echo "ac_add_options --disable-system-cairo" >> .mozconfig +%endif + +%if %{?system_harfbuzz} +echo "ac_add_options --enable-system-graphite2" >> .mozconfig +echo "ac_add_options --enable-system-harfbuzz" >> .mozconfig +%else +echo "ac_add_options --disable-system-graphite2" >> .mozconfig +echo "ac_add_options --disable-system-harfbuzz" >> .mozconfig +%endif + +%if %{?system_ffi} +echo "ac_add_options --enable-system-ffi" >> .mozconfig +%endif + +%ifarch %{arm} +echo "ac_add_options --disable-elf-hack" >> .mozconfig +%endif + +%if %{?alsa_backend} +echo "ac_add_options --enable-alsa" >> .mozconfig +%endif + +%if %{?system_hunspell} +echo "ac_add_options --enable-system-hunspell" >> .mozconfig +%else +echo "ac_add_options --disable-system-hunspell" >> .mozconfig +%endif + +%if %{?system_libevent} +echo "ac_add_options --enable-system-libevent" >> .mozconfig +%else +echo "ac_add_options --disable-system-libevent" >> .mozconfig +%endif + +%if %{?debug_build} +echo "ac_add_options --enable-debug" >> .mozconfig +echo "ac_add_options --disable-optimize" >> .mozconfig +%else +%global optimize_flags "none" +# Fedora 26 (gcc7) needs to disable default build flags (mozbz#1342344) +%ifnarch s390 s390x +%global optimize_flags "-g -O2" +%endif +%ifarch armv7hl +# ARMv7 need that (rhbz#1426850) +%global optimize_flags "-g -O2 -fno-schedule-insns" +%endif +%ifarch ppc64le aarch64 +%global optimize_flags "-g -O2" +%endif +%if %{optimize_flags} != "none" +echo 'ac_add_options --enable-optimize=%{?optimize_flags}' >> .mozconfig +%else +echo 'ac_add_options --enable-optimize' >> .mozconfig +%endif +echo "ac_add_options --disable-debug" >> .mozconfig +%endif + +# s390(x) fails to start with jemalloc enabled +%ifarch s390 s390x +echo "ac_add_options --disable-jemalloc" >> .mozconfig +%endif + +%ifnarch %{ix86} x86_64 +echo "ac_add_options --disable-webrtc" >> .mozconfig +%endif + +%if %{?run_tests} +echo "ac_add_options --enable-tests" >> .mozconfig +%endif + +%if !%{?system_jpeg} +echo "ac_add_options --without-system-jpeg" >> .mozconfig +%else +echo "ac_add_options --with-system-jpeg" >> .mozconfig +%endif + +%if %{?system_libvpx} +echo "ac_add_options --with-system-libvpx" >> .mozconfig +%else +echo "ac_add_options --without-system-libvpx" >> .mozconfig +%endif + +%if %{?system_webp} +echo "ac_add_options --with-system-webp" >> .mozconfig +%else +echo "ac_add_options --without-system-webp" >> .mozconfig +%endif + +%if %{?system_vorbis} +echo "ac_add_options --with-system-ogg" >> .mozconfig +echo "ac_add_options --with-system-vorbis" >> .mozconfig +%else +echo "ac_add_options --without-system-ogg" >> .mozconfig +echo "ac_add_options --without-system-vorbis" >> .mozconfig +%endif + +%if %{?system_libicu} +echo "ac_add_options --with-system-icu" >> .mozconfig +%else +echo "ac_add_options --without-system-icu" >> .mozconfig +%endif +%ifarch s390 s390x +echo "ac_add_options --disable-ion" >> .mozconfig +%endif + + +#--------------------------------------------------------------------- + +%build +%if %{?system_sqlite} +# Do not proceed with build if the sqlite require would be broken: +# make sure the minimum requirement is non-empty, ... +sqlite_version=$(expr "%{sqlite_version}" : '\([0-9]*\.\)[0-9]*\.') || exit 1 +# ... and that major number of the computed build-time version matches: +case "%{sqlite_build_version}" in + "$sqlite_version"*) ;; + *) exit 1 ;; +esac +%endif + +echo "Generate big endian version of config/external/icu/data/icud58l.dat" +%if 0%{?big_endian} + ./mach python intl/icu_sources_data.py . + ls -l config/external/icu/data + rm -f config/external/icu/data/icudt*l.dat +%endif + +# Update the various config.guess to upstream release for aarch64 support +find ./ -name config.guess -exec cp /usr/lib/rpm/config.guess {} ';' + +# -fpermissive is needed to build with gcc 4.6+ which has become stricter +# +# Mozilla builds with -Wall with exception of a few warnings which show up +# everywhere in the code; so, don't override that. +# +# Disable C++ exceptions since Mozilla code is not exception-safe +# +MOZ_OPT_FLAGS=$(echo "%{optflags}" | %{__sed} -e 's/-Wall//') +#rhbz#1037063 +# -Werror=format-security causes build failures when -Wno-format is explicitly given +# for some sources +# Explicitly force the hardening flags for Waterfox so it passes the checksec test; +# See also https://fedoraproject.org/wiki/Changes/Harden_All_Packages +MOZ_OPT_FLAGS="$MOZ_OPT_FLAGS -Wformat-security -Wformat -Werror=format-security" +# Disable null pointer gcc6 optimization in gcc6 (rhbz#1328045) +MOZ_OPT_FLAGS="$MOZ_OPT_FLAGS -fno-delete-null-pointer-checks" +# Use hardened build? +%if %{?hardened_build} +MOZ_OPT_FLAGS="$MOZ_OPT_FLAGS -fPIC -Wl,-z,relro -Wl,-z,now" +%endif +%if %{?debug_build} +MOZ_OPT_FLAGS=$(echo "$MOZ_OPT_FLAGS" | %{__sed} -e 's/-O2//') +%endif +%ifarch s390 +MOZ_OPT_FLAGS=$(echo "$MOZ_OPT_FLAGS" | %{__sed} -e 's/-g/-g1/') +# If MOZ_DEBUG_FLAGS is empty, waterfox's build will default it to "-g" which +# overrides the -g1 from line above and breaks building on s390 +# (OOM when linking, rhbz#1238225) +export MOZ_DEBUG_FLAGS=" " +%endif +%ifarch s390 %{arm} ppc aarch64 +MOZ_LINK_FLAGS="-Wl,--no-keep-memory -Wl,--reduce-memory-overheads" +%endif +export CFLAGS=$MOZ_OPT_FLAGS +export CXXFLAGS=$MOZ_OPT_FLAGS +export LDFLAGS=$MOZ_LINK_FLAGS + +export PREFIX='%{_prefix}' +export LIBDIR='%{_libdir}' + +MOZ_SMP_FLAGS=-j1 +# On x86 architectures, Mozilla can build up to 4 jobs at once in parallel, +# however builds tend to fail on other arches when building in parallel. +%ifarch %{ix86} x86_64 ppc ppc64 ppc64le aarch64 +[ -z "$RPM_BUILD_NCPUS" ] && \ + RPM_BUILD_NCPUS="`/usr/bin/getconf _NPROCESSORS_ONLN`" +[ "$RPM_BUILD_NCPUS" -ge 2 ] && MOZ_SMP_FLAGS=-j2 +[ "$RPM_BUILD_NCPUS" -ge 4 ] && MOZ_SMP_FLAGS=-j4 +[ "$RPM_BUILD_NCPUS" -ge 8 ] && MOZ_SMP_FLAGS=-j8 +%endif + +make -f client.mk build STRIP="/bin/true" MOZ_MAKE_FLAGS="$MOZ_SMP_FLAGS" MOZ_SERVICES_SYNC="1" + +%if %{?run_tests} +%if %{?system_nss} +ln -s /usr/bin/certutil objdir/dist/bin/certutil +ln -s /usr/bin/pk12util objdir/dist/bin/pk12util + +%endif +mkdir test_results +./mach --log-no-times check-spidermonkey &> test_results/check-spidermonkey || true +./mach --log-no-times check-spidermonkey &> test_results/check-spidermonkey-2nd-run || true +./mach --log-no-times cppunittest &> test_results/cppunittest || true +xvfb-run ./mach --log-no-times crashtest &> test_results/crashtest || true +./mach --log-no-times gtest &> test_results/gtest || true +xvfb-run ./mach --log-no-times jetpack-test &> test_results/jetpack-test || true +# not working right now ./mach marionette-test &> test_results/marionette-test || true +xvfb-run ./mach --log-no-times mochitest-a11y &> test_results/mochitest-a11y || true +xvfb-run ./mach --log-no-times mochitest-browser &> test_results/mochitest-browser || true +xvfb-run ./mach --log-no-times mochitest-chrome &> test_results/mochitest-chrome || true +xvfb-run ./mach --log-no-times mochitest-devtools &> test_results/mochitest-devtools || true +xvfb-run ./mach --log-no-times mochitest-plain &> test_results/mochitest-plain || true +xvfb-run ./mach --log-no-times reftest &> test_results/reftest || true +xvfb-run ./mach --log-no-times webapprt-test-chrome &> test_results/webapprt-test-chrome || true +xvfb-run ./mach --log-no-times webapprt-test-content &> test_results/webapprt-test-content || true +./mach --log-no-times webidl-parser-test &> test_results/webidl-parser-test || true +xvfb-run ./mach --log-no-times xpcshell-test &> test_results/xpcshell-test || true +%if %{?system_nss} +rm -f objdir/dist/bin/certutil +rm -f objdir/dist/bin/pk12util +%endif + +%endif +#--------------------------------------------------------------------- + +%install + +# set up our default bookmarks +cp -p %{default_bookmarks_file} objdir/dist/bin/browser/chrome/en-US/locale/browser/bookmarks.html + +# Make sure locale works for langpacks +cat > objdir/dist/bin/browser/defaults/preferences/firefox-l10n.js << EOF +pref("general.useragent.locale", "chrome://global/locale/intl.properties"); +EOF + +DESTDIR=%{buildroot} make -C objdir install + +mkdir -p %{buildroot}{%{_libdir},%{_bindir},%{_datadir}/applications} + +desktop-file-install --dir %{buildroot}%{_datadir}/applications %{SOURCE20} + +# set up the waterfox start script +rm -rf %{buildroot}%{_bindir}/waterfox +cat %{SOURCE21} > %{buildroot}%{_bindir}/waterfox +chmod 755 %{buildroot}%{_bindir}/waterfox + +install -p -D -m 644 %{SOURCE23} %{buildroot}%{_mandir}/man1/waterfox.1 + +rm -f %{buildroot}/%{mozappdir}/waterfox-config +rm -f %{buildroot}/%{mozappdir}/update-settings.ini + +for s in 16 22 24 32 48 256; do + mkdir -p %{buildroot}%{_datadir}/icons/hicolor/${s}x${s}/apps + cp -p browser/branding/unofficial/default${s}.png \ + %{buildroot}%{_datadir}/icons/hicolor/${s}x${s}/apps/waterfox.png +done + +# Register as an application to be visible in the software center +# +# NOTE: It would be *awesome* if this file was maintained by the upstream +# project, translated and installed into the right place during `make install`. +# +# See http://www.freedesktop.org/software/appstream/docs/ for more details. +# +mkdir -p %{buildroot}%{_metainfodir} +cat > %{buildroot}%{_metainfodir}/%{name}.appdata.xml <<EOF +<?xml version="1.0" encoding="UTF-8"?> +<!-- Copyright 2014 Richard Hughes <richard@hughsie.com> --> +<application> + <id type="desktop">waterfox.desktop</id> + <metadata_license>CC0-1.0</metadata_license> + <description> + <p> + Bringing together all kinds of awesomeness to make browsing better for you. + Get to your favorite sites quickly – even if you don’t remember the URLs. + Type your term into the location bar (aka the Awesome Bar) and the autocomplete + function will include possible matches from your browsing history, bookmarked + sites and open tabs. + </p> + <!-- FIXME: Needs another couple of paragraphs --> + </description> + <url type="homepage">http://www.mozilla.org/</url> + <!-- FIXME: change this to an upstream email address for spec updates + <updatecontact>someone_who_cares@upstream_project.org</updatecontact> + --> +</application> +EOF + +echo > %{name}.lang +%if %{build_langpacks} +# Extract langpacks, make any mods needed, repack the langpack, and install it. +mkdir -p %{buildroot}%{langpackdir} +for langpack in `ls waterfox-langpacks/*.xpi`; do + language=`basename $langpack .xpi | sed -e 's/^langpack-//' -e 's/@waterfox//'` + extensionID=langpack-$language@waterfox + mkdir -p $extensionID + unzip -qq $langpack -d $extensionID + find $extensionID -type f | xargs chmod 644 + + cd $extensionID + zip -qq -r9mX ../${extensionID}.xpi * + cd - + + install -m 644 ${extensionID}.xpi %{buildroot}%{langpackdir} + language=`echo $language | sed -e 's/-/_/g'` + echo "%%lang($language) %{langpackdir}/${extensionID}.xpi" >> %{name}.lang +done +rm -rf waterfox-langpacks + +# Install langpack workaround (see #707100, #821169) +function create_default_langpack() { +language_long=$1 +language_short=$2 +cd %{buildroot}%{langpackdir} +ln -s langpack-$language_long@waterfox.xpi langpack-$language_short@waterfox.xpi +cd - +echo "%%lang($language_short) %{langpackdir}/langpack-$language_short@waterfox.xpi" >> %{name}.lang +} + +# Table of fallbacks for each language +create_default_langpack "bn-IN" "bn" +create_default_langpack "es-AR" "es" +create_default_langpack "fy-NL" "fy" +create_default_langpack "ga-IE" "ga" +create_default_langpack "gu-IN" "gu" +create_default_langpack "hi-IN" "hi" +create_default_langpack "hy-AM" "hy" +create_default_langpack "nb-NO" "nb" +create_default_langpack "nn-NO" "nn" +create_default_langpack "pa-IN" "pa" +create_default_langpack "pt-PT" "pt" +create_default_langpack "sv-SE" "sv" +create_default_langpack "zh-TW" "zh" +%endif # build_langpacks + +mkdir -p %{buildroot}/%{mozappdir}/browser/features + +mkdir -p %{buildroot}/%{mozappdir}/browser/defaults/preferences + +# System config dir +mkdir -p %{buildroot}/%{_sysconfdir}/%{name}/pref + +# System extensions +mkdir -p %{buildroot}%{_datadir}/waterfox/extensions/%{waterfox_app_id} +mkdir -p %{buildroot}%{_libdir}/waterfox/extensions/%{waterfox_app_id} + +# Copy over the LICENSE +install -p -c -m 644 LICENSE %{buildroot}/%{mozappdir} + +# Use the system hunspell dictionaries +rm -rf %{buildroot}%{mozappdir}/dictionaries +ln -s %{_datadir}/myspell %{buildroot}%{mozappdir}/dictionaries + +%if %{run_tests} +# Add debuginfo for crash-stats.mozilla.com +mkdir -p %{buildroot}/test_results +cp test_results/* %{buildroot}/test_results +%endif + +# Default +cp %{SOURCE12} %{buildroot}%{mozappdir}/browser/defaults/preferences + +# Add distribution.ini +mkdir -p %{buildroot}%{mozappdir}/distribution +cp %{SOURCE26} %{buildroot}%{mozappdir}/distribution + +# Remove copied libraries to speed up build +rm -f %{buildroot}%{mozappdirdev}/sdk/lib/libmozjs.so +rm -f %{buildroot}%{mozappdirdev}/sdk/lib/libmozalloc.so +rm -f %{buildroot}%{mozappdirdev}/sdk/lib/libxul.so +#--------------------------------------------------------------------- + +# Moves defaults/preferences to browser/defaults/preferences +%pretrans -p <lua> +require 'posix' +require 'os' +if (posix.stat("%{mozappdir}/browser/defaults/preferences", "type") == "link") then + posix.unlink("%{mozappdir}/browser/defaults/preferences") + posix.mkdir("%{mozappdir}/browser/defaults/preferences") + if (posix.stat("%{mozappdir}/defaults/preferences", "type") == "directory") then + for i,filename in pairs(posix.dir("%{mozappdir}/defaults/preferences")) do + os.rename("%{mozappdir}/defaults/preferences/"..filename, "%{mozappdir}/browser/defaults/preferences/"..filename) + end + f = io.open("%{mozappdir}/defaults/preferences/README","w") + if f then + f:write("Content of this directory has been moved to %{mozappdir}/browser/defaults/preferences.") + f:close() + end + end +end + + +%preun +# is it a final removal? +if [ $1 -eq 0 ]; then + rm -rf %{mozappdir}/components + rm -rf %{langpackdir} +fi + +%files -f %{name}.lang +%{_bindir}/waterfox +%{mozappdir}/waterfox +%{mozappdir}/waterfox-bin +%doc %{_mandir}/man1/* +%dir %{_sysconfdir}/%{name} +%dir %{_sysconfdir}/%{name}/* +%dir %{_datadir}/waterfox/extensions/* +%dir %{_libdir}/waterfox/extensions/* +%{_metainfodir}/*.appdata.xml +%{_datadir}/applications/*.desktop +%dir %{mozappdir} +%license %{mozappdir}/LICENSE +%{mozappdir}/browser/chrome +%{mozappdir}/browser/chrome.manifest +%{mozappdir}/browser/defaults/preferences/waterfox-chinfo-default-prefs.js +%{mozappdir}/browser/features +%{mozappdir}/distribution/distribution.ini +# That's Windows only +%ghost %{mozappdir}/browser/features/aushelper@mozilla.org.xpi +%attr(644, root, root) %{mozappdir}/browser/blocklist.xml +%dir %{mozappdir}/browser/extensions +%{mozappdir}/browser/extensions/* +%if %{build_langpacks} +%dir %{langpackdir} +%endif +%{mozappdir}/browser/omni.ja +%{mozappdir}/browser/icons +%{mozappdir}/chrome.manifest +%{mozappdir}/run-mozilla.sh +%{mozappdir}/application.ini +%exclude %{mozappdir}/removed-files +%{_datadir}/icons/hicolor/16x16/apps/waterfox.png +%{_datadir}/icons/hicolor/22x22/apps/waterfox.png +%{_datadir}/icons/hicolor/24x24/apps/waterfox.png +%{_datadir}/icons/hicolor/256x256/apps/waterfox.png +%{_datadir}/icons/hicolor/32x32/apps/waterfox.png +%{_datadir}/icons/hicolor/48x48/apps/waterfox.png +%{mozappdir}/*.so +%{mozappdir}/gtk2/*.so +%{mozappdir}/defaults/pref/channel-prefs.js +%{mozappdir}/dependentlibs.list +%{mozappdir}/dictionaries +%{mozappdir}/omni.ja +%{mozappdir}/platform.ini +%{mozappdir}/plugin-container +%{mozappdir}/gmp-clearkey +%{mozappdir}/fonts/EmojiOneMozilla.ttf +%if !%{?system_libicu} +%{mozappdir}/icudt*.dat +%endif +%if !%{?system_nss} +%{mozappdir}/libfreeblpriv3.chk +%{mozappdir}/libnssdbm3.chk +%{mozappdir}/libsoftokn3.chk +%exclude %{mozappdir}/libnssckbi.so +%endif + +#--------------------------------------------------------------------- + +%changelog +* Sun Sep 09 2018 Phantom X <megaphantomx at bol dot com dot br> - 56.2.2-4.20180908git2294d45 +- New snapshot +- clang only build switch + +* Sun Jul 15 2018 Phantom X <megaphantomx at bol dot com dot br> - 56.2.2-3.20180807git9a88873 +- Crash fixes + +* Sun Jul 15 2018 Phantom X <megaphantomx at bol dot com dot br> - 56.2.2-2.20180713giteb9e7d6 +- New release + +* Thu Jul 05 2018 Phantom X <megaphantomx at bol dot com dot br> - 56.2.2-1.20180618gitb7b9ee7 +- New release/snapshot + +* Wed Jul 04 2018 Phantom X <megaphantomx at bol dot com dot br> - 56.2.1-2.20180618git75c40de +- New snapshot + +* Tue Jun 19 2018 Phantom X <megaphantomx at bol dot com dot br> - 56.2.1-1.20180618gitff88ad0 +- New release/snapshot + +* Sat Jun 09 2018 Phantom X <megaphantomx at bol dot com dot br> - 56.2.0-3.20180530gitf435a82 +- New release/snapshot + +* Tue May 29 2018 Phantom X <megaphantomx at bol dot com dot br> - 56.2.0-2.20180527git01e6727 +- New release/snapshot +- Update patchset + +* Tue May 15 2018 Phantom X <megaphantomx at bol dot com dot br> - 56.2.0-1.20180514git4368983 +- New release/snapshot +- Update patchset + +* Mon May 14 2018 Phantom X <megaphantomx at bol dot com dot br> - 56.1.0-7.20180514git94abeb3 +- New snapshot +- Update patchset +- Rebrand waterfox.sh.in + +* Sat May 12 2018 Phantom X <megaphantomx at bol dot com dot br> - 56.1.0-6.20180511git2bb1a86 +- New snapshot +- Update patchset + +* Tue May 01 2018 Phantom X <megaphantomx at bol dot com dot br> - 56.1.0-5.20180430gitd5c2541 +- New snapshot +- Update patchset +- Enable system webp + +* Tue Apr 24 2018 Phantom X <megaphantomx at bol dot com dot br> - 56.1.0-4.20180419git8864091 +- Some more FreeBSD backport patches, BR: patchutils +- Enable ogg/vorbis, BR: pkgconfig(vorbis) + +* Thu Apr 19 2018 Phantom X <megaphantomx at bol dot com dot br> - 56.1.0-3.20180419git8864091 +- Apply most of FreeBSD backport patches +- Enable system libevent and harfbuzz + +* Sat Apr 14 2018 Phantom X <megaphantomx at bol dot com dot br> - 56.1.0-2.20180412gita52b5ea +- Build latest snapshot for servo fixes +- Drop unneeded patches +- gcc 8 fix + +* Fri Apr 06 2018 Phantom X <megaphantomx at bol dot com dot br> - 56.1.0-1 +- 56.1.0 + +* Fri Feb 02 2018 Phantom X <megaphantomx at bol dot com dot br> - 56.0.4-1 +- 56.0.4 + +* Fri Jan 12 2018 Phantom X <megaphantomx at bol dot com dot br> - 56.0.3-1 +- 56.0.3 + +* Fri Jan 05 2018 Phantom X <megaphantomx at bol dot com dot br> - 56.0.2-1 +- 56.0.2 +- Fix release tarball support +- Unused patches cleanup +- Fix man + +* Wed Dec 27 2017 Phantom X <megaphantomx at bol dot com dot br> - 56.0.1-4.20171213git388770f +- New patch to ~/.waterfox/{extensions,plugins} and /usr/share/waterfox +- R: waterfox-filesystem + +* Tue Dec 26 2017 Phantom X <megaphantomx at bol dot com dot br> - 56.0.1-3.20171213git388770f +- New snapshot +- BR: libevent, disabled, needs new releases +- Patch to use ~/.waterfox/extensions + +* Tue Dec 19 2017 Phantom X <megaphantomx at bol dot com dot br> - 56.0.1-2.20171213git7b7aa8b +- Fixes borrowed from FreeBSD +- Enable stylo +- Do not use api keys from Fedora Firefox package +- Build with gold + +* Wed Dec 13 2017 Phantom X <megaphantomx at bol dot com dot br> - 56.0.1-1.20171213git7b7aa8b +- First spec, borrowed from Fedora Firefox |