# Copyright 1999-2020 Gentoo Authors # Distributed under the terms of the GNU General Public License v2 EAPI="6" VIRTUALX_REQUIRED="pgo" WANT_AUTOCONF="2.1" MOZ_ESR="1" PYTHON_COMPAT=( python3_{6,7,8,9} ) PYTHON_REQ_USE='ncurses,sqlite,ssl,threads(+)' # This list can be updated with scripts/get_langs.sh from the mozilla overlay MOZ_LANGS=( ach af an ar ast az be bg bn br bs ca cak cs cy da de dsb el en en-CA en-GB en-US eo es-AR es-CL es-ES es-MX et eu fa ff fi fr fy-NL ga-IE gd gl gn gu-IN he hi-IN hr hsb hu hy-AM ia id is it ja ka kab kk km kn ko lij lt lv mk mr ms my nb-NO nl nn-NO oc pa-IN pl pt-BR pt-PT rm ro ru si sk sl son sq sr sv-SE ta te th tr uk ur uz vi xh zh-CN zh-TW ) # Convert the ebuild version to the upstream mozilla version, used by mozlinguas MOZ_PV="${PV/_alpha/a}" # Handle alpha for SRC_URI MOZ_PV="${MOZ_PV/_beta/b}" # Handle beta for SRC_URI MOZ_PV="${MOZ_PV%%_rc*}" # Handle rc for SRC_URI if [[ ${MOZ_ESR} == 1 ]] ; then # ESR releases have slightly different version numbers MOZ_PV="${MOZ_PV}esr" fi # Patch version PATCH="${PN}-68.0-patches-14" MOZ_HTTP_URI="https://archive.mozilla.org/pub/${PN}/releases" MOZ_SRC_URI="${MOZ_HTTP_URI}/${MOZ_PV}/source/${PN}-${MOZ_PV}.source.tar.xz" if [[ "${PV}" == *_rc* ]]; then MOZ_HTTP_URI="https://archive.mozilla.org/pub/${PN}/candidates/${MOZ_PV}-candidates/build${PV##*_rc}" MOZ_LANGPACK_PREFIX="linux-i686/xpi/" MOZ_SRC_URI="${MOZ_HTTP_URI}/source/${PN}-${MOZ_PV}.source.tar.xz -> $P.tar.xz" fi LLVM_MAX_SLOT=10 inherit check-reqs eapi7-ver flag-o-matic toolchain-funcs eutils \ gnome2-utils llvm mozcoreconf-v6 pax-utils xdg-utils \ autotools mozlinguas-v2 multiprocessing virtualx DESCRIPTION="Firefox Web Browser" HOMEPAGE="https://www.mozilla.com/firefox" KEYWORDS="amd64 arm64 ~ppc64 x86" SLOT="0" LICENSE="MPL-2.0 GPL-2 LGPL-2.1" IUSE="bindist clang cpu_flags_x86_avx2 dbus debug eme-free geckodriver +gmp-autoupdate hardened hwaccel jack lto cpu_flags_arm_neon +openh264 pgo pulseaudio +screenshot selinux startup-notification +system-av1 +system-harfbuzz +system-icu +system-jpeg +system-libevent +system-sqlite +system-libvpx +system-webp test wayland wifi" REQUIRED_USE="pgo? ( lto ) wifi? ( dbus )" RESTRICT="!bindist? ( bindist ) !test? ( test )" PATCH_URIS=( https://dev.gentoo.org/~{anarchy,axs,polynomial-c,whissi}/mozilla/patchsets/${PATCH}.tar.xz ) SRC_URI="${SRC_URI} ${MOZ_SRC_URI} ${PATCH_URIS[@]}" CDEPEND=" >=dev-libs/nss-3.44.4 >=dev-libs/nspr-4.21 dev-libs/atk dev-libs/expat >=x11-libs/cairo-1.10[X] >=x11-libs/gtk+-2.18:2 >=x11-libs/gtk+-3.4.0:3[X] x11-libs/gdk-pixbuf >=x11-libs/pango-1.22.0 >=media-libs/libpng-1.6.35:0=[apng] >=media-libs/mesa-10.2:* media-libs/fontconfig >=media-libs/freetype-2.4.10 kernel_linux? ( !pulseaudio? ( media-libs/alsa-lib ) ) virtual/freedesktop-icon-theme dbus? ( >=sys-apps/dbus-0.60 >=dev-libs/dbus-glib-0.72 ) startup-notification? ( >=x11-libs/startup-notification-0.8 ) >=x11-libs/pixman-0.19.2 >=dev-libs/glib-2.26:2 >=sys-libs/zlib-1.2.3 >=dev-libs/libffi-3.0.10:= media-video/ffmpeg x11-libs/libX11 x11-libs/libXcomposite x11-libs/libXdamage x11-libs/libXext x11-libs/libXfixes x11-libs/libXrender x11-libs/libXt system-av1? ( >=media-libs/dav1d-0.3.0:= >=media-libs/libaom-1.0.0:= ) system-harfbuzz? ( >=media-libs/harfbuzz-2.4.0:0= >=media-gfx/graphite2-1.3.13 ) system-icu? ( >=dev-libs/icu-63.1:= ) system-jpeg? ( >=media-libs/libjpeg-turbo-1.2.1 ) system-libevent? ( >=dev-libs/libevent-2.0:0=[threads] ) system-libvpx? ( =media-libs/libvpx-1.7*:0=[postproc] ) system-sqlite? ( >=dev-db/sqlite-3.28.0:3[secure-delete,debug=] ) system-webp? ( >=media-libs/libwebp-1.0.2:0= ) wifi? ( kernel_linux? ( >=sys-apps/dbus-0.60 >=dev-libs/dbus-glib-0.72 net-misc/networkmanager ) ) jack? ( virtual/jack ) selinux? ( sec-policy/selinux-mozilla )" RDEPEND="${CDEPEND} jack? ( virtual/jack ) openh264? ( media-libs/openh264:*[plugin] ) pulseaudio? ( || ( media-sound/pulseaudio >=media-sound/apulse-0.1.9 ) ) selinux? ( sec-policy/selinux-mozilla )" DEPEND="${CDEPEND} app-arch/zip app-arch/unzip >=dev-util/cbindgen-0.8.7 >=net-libs/nodejs-8.11.0 >=sys-devel/binutils-2.30 sys-apps/findutils virtual/pkgconfig >=virtual/rust-1.34.0 =x11-libs/gtk+-3.11:3[wayland] ) amd64? ( >=dev-lang/yasm-1.1 virtual/opengl ) x86? ( >=dev-lang/yasm-1.1 virtual/opengl ) !system-av1? ( amd64? ( >=dev-lang/nasm-2.13 ) x86? ( >=dev-lang/nasm-2.13 ) )" S="${WORKDIR}/firefox-${PV%_*}" BUILD_OBJ_DIR="${S}/ff" # allow GMP_PLUGIN_LIST to be set in an eclass or # overridden in the enviromnent (advanced hackers only) if [[ -z $GMP_PLUGIN_LIST ]] ; then GMP_PLUGIN_LIST=( gmp-gmpopenh264 gmp-widevinecdm ) fi llvm_check_deps() { if ! has_version --host-root "sys-devel/clang:${LLVM_SLOT}" ; then ewarn "sys-devel/clang:${LLVM_SLOT} is missing! Cannot use LLVM slot ${LLVM_SLOT} ..." >&2 return 1 fi if use clang ; then if ! has_version --host-root "=sys-devel/lld-${LLVM_SLOT}*" ; then ewarn "=sys-devel/lld-${LLVM_SLOT}* is missing! Cannot use LLVM slot ${LLVM_SLOT} ..." >&2 return 1 fi if use pgo ; then if ! has_version --host-root "=sys-libs/compiler-rt-sanitizers-${LLVM_SLOT}*" ; then ewarn "=sys-libs/compiler-rt-sanitizers-${LLVM_SLOT}* is missing! Cannot use LLVM slot ${LLVM_SLOT} ..." >&2 return 1 fi fi fi einfo "Will use LLVM slot ${LLVM_SLOT}!" >&2 } pkg_pretend() { if [[ ${MERGE_TYPE} != binary ]] ; then local rustc_version=( $(eselect --brief rust show 2>/dev/null) ) rustc_version=${rustc_version[0]/rust-bin-/} rustc_version=${rustc_version/rust-/} if [[ -n "${rustc_version}" ]] ; then if ver_test "${rustc_version}" -ge "1.45.0" ; then die "Rust >=1.45.0 is not supported. Please use 'eselect rust' to switch to /dev/null) ) rustc_version=${rustc_version[0]/rust-bin-/} rustc_version=${rustc_version/rust-/} [[ -z "${rustc_version}" ]] && die "Failed to determine rustc version!" if ver_test "${rustc_version}" -ge "1.45.0" ; then die "Rust >=1.45.0 is not supported. Please use 'eselect rust' to switch to =gcc-8 or >=clang-7)." ewarn "You are on your own -- expect build failures. Don't file bugs using that unsupported configuration!" ewarn "" sleep 5 fi mozconfig_annotate '+lto' --enable-lto=thin if use pgo ; then mozconfig_annotate '+pgo' MOZ_PGO=1 fi else # Avoid auto-magic on linker if use clang ; then # This is upstream's default mozconfig_annotate "forcing ld=lld due to USE=clang" --enable-linker=lld elif tc-ld-is-gold ; then mozconfig_annotate "linker is set to gold" --enable-linker=gold else mozconfig_annotate "linker is set to bfd" --enable-linker=bfd fi fi # It doesn't compile on alpha without this LDFLAGS use alpha && append-ldflags "-Wl,--no-relax" # Add full relro support for hardened if use hardened ; then append-ldflags "-Wl,-z,relro,-z,now" mozconfig_use_enable hardened hardening fi # Modifications to better support ARM, bug 553364 if use cpu_flags_arm_neon ; then mozconfig_annotate '' --with-fpu=neon if ! tc-is-clang ; then # thumb options aren't supported when using clang, bug 666966 mozconfig_annotate '' --with-thumb=yes mozconfig_annotate '' --with-thumb-interwork=no fi fi if [[ ${CHOST} == armv*h* ]] ; then mozconfig_annotate '' --with-float-abi=hard if ! use system-libvpx ; then sed -i -e "s|softfp|hard|" \ "${S}"/media/libvpx/moz.build fi fi mozconfig_use_enable !bindist official-branding mozconfig_use_enable debug mozconfig_use_enable debug tests if ! use debug ; then mozconfig_annotate 'disabled by Gentoo' --disable-debug-symbols else mozconfig_annotate 'enabled by Gentoo' --enable-debug-symbols fi # These are enabled by default in all mozilla applications mozconfig_annotate '' --with-system-nspr --with-nspr-prefix="${SYSROOT}${EPREFIX}"/usr mozconfig_annotate '' --with-system-nss --with-nss-prefix="${SYSROOT}${EPREFIX}"/usr mozconfig_annotate '' --x-includes="${SYSROOT}${EPREFIX}"/usr/include \ --x-libraries="${SYSROOT}${EPREFIX}"/usr/$(get_libdir) mozconfig_annotate '' --prefix="${EPREFIX}"/usr mozconfig_annotate '' --libdir="${EPREFIX}"/usr/$(get_libdir) mozconfig_annotate '' --disable-crashreporter mozconfig_annotate 'Gentoo default' --with-system-png mozconfig_annotate '' --enable-system-ffi mozconfig_annotate '' --disable-gconf mozconfig_annotate '' --with-intl-api mozconfig_annotate '' --enable-system-pixman # Instead of the standard --build= and --host=, mozilla uses --host instead # of --build, and --target intstead of --host. # Note, mozilla also has --build but it does not do what you think it does. # Set both --target and --host as mozilla uses python to guess values otherwise mozconfig_annotate '' --target="${CHOST}" mozconfig_annotate '' --host="${CBUILD:-${CHOST}}" mozconfig_annotate '' --with-toolchain-prefix="${CHOST}-" if use system-libevent ; then mozconfig_annotate '' --with-system-libevent="${SYSROOT}${EPREFIX}"/usr fi if ! use x86 && [[ ${CHOST} != armv*h* ]] ; then mozconfig_annotate '' --enable-rust-simd fi # use the gtk3 toolkit (the only one supported at this point) # TODO: Will this result in automagic dependency on x11-libs/gtk+[wayland]? if use wayland ; then mozconfig_annotate '' --enable-default-toolkit=cairo-gtk3-wayland else mozconfig_annotate '' --enable-default-toolkit=cairo-gtk3 fi mozconfig_use_enable startup-notification mozconfig_use_enable system-sqlite mozconfig_use_with system-av1 mozconfig_use_with system-harfbuzz mozconfig_use_with system-harfbuzz system-graphite2 mozconfig_use_with system-icu mozconfig_use_with system-jpeg mozconfig_use_with system-libvpx mozconfig_use_with system-webp mozconfig_use_enable pulseaudio # force the deprecated alsa sound code if pulseaudio is disabled if use kernel_linux && ! use pulseaudio ; then mozconfig_annotate '-pulseaudio' --enable-alsa fi # Disable built-in ccache support to avoid sandbox violation, #665420 # Use FEATURES=ccache instead! mozconfig_annotate '' --without-ccache sed -i -e 's/ccache_stats = None/return None/' \ python/mozbuild/mozbuild/controller/building.py || \ die "Failed to disable ccache stats call" mozconfig_use_enable dbus mozconfig_use_enable wifi necko-wifi mozconfig_use_enable geckodriver # enable JACK, bug 600002 mozconfig_use_enable jack # Enable/Disable eme support use eme-free && mozconfig_annotate '+eme-free' --disable-eme # Setup api key for location services and safebrowsing, https://bugzilla.mozilla.org/show_bug.cgi?id=1531176#c34 echo -n "${_google_api_key}" > "${S}"/google-api-key mozconfig_annotate '' --with-google-location-service-api-keyfile="${S}/google-api-key" mozconfig_annotate '' --with-google-safebrowsing-api-keyfile="${S}/google-api-key" mozconfig_annotate '' --enable-extensions="${MEXTENSIONS}" # allow elfhack to work in combination with unstripped binaries # when they would normally be larger than 2GiB. append-ldflags "-Wl,--compress-debug-sections=zlib" if use clang ; then # https://bugzilla.mozilla.org/show_bug.cgi?id=1482204 # https://bugzilla.mozilla.org/show_bug.cgi?id=1483822 # toolkit/moz.configure Elfhack section: target.cpu in ('arm', 'x86', 'x86_64') local disable_elf_hack= if use amd64 ; then disable_elf_hack=yes elif use x86 ; then disable_elf_hack=yes elif use arm ; then disable_elf_hack=yes fi if [[ -n ${disable_elf_hack} ]] ; then mozconfig_annotate 'elf-hack is broken when using Clang' --disable-elf-hack fi fi echo "mk_add_options MOZ_OBJDIR=${BUILD_OBJ_DIR}" >> "${S}"/.mozconfig echo "mk_add_options XARGS=/usr/bin/xargs" >> "${S}"/.mozconfig # Finalize and report settings mozconfig_final mkdir -p "${S}"/third_party/rust/libloading/.deps # workaround for funky/broken upstream configure... SHELL="${SHELL:-${EPREFIX}/bin/bash}" MOZ_NOSPAM=1 \ ./mach configure || die } src_compile() { local _virtx= if use pgo ; then _virtx=virtx # Reset and cleanup environment variables used by GNOME/XDG gnome2_environment_reset addpredict /root addpredict /etc/gconf fi GDK_BACKEND=x11 \ MOZ_MAKE_FLAGS="${MAKEOPTS} -O" \ SHELL="${SHELL:-${EPREFIX}/bin/bash}" \ MOZ_NOSPAM=1 \ ${_virtx} \ ./mach build --verbose \ || die } src_install() { cd "${BUILD_OBJ_DIR}" || die # Pax mark xpcshell for hardened support, only used for startupcache creation. pax-mark m "${BUILD_OBJ_DIR}"/dist/bin/xpcshell # Add our default prefs for firefox cp "${FILESDIR}"/gentoo-default-prefs.js-3 \ "${BUILD_OBJ_DIR}/dist/bin/browser/defaults/preferences/all-gentoo.js" \ || die # set dictionary path, to use system hunspell echo "pref(\"spellchecker.dictionary_path\", \"${EPREFIX}/usr/share/myspell\");" \ >>"${BUILD_OBJ_DIR}/dist/bin/browser/defaults/preferences/all-gentoo.js" || die # force the graphite pref if system-harfbuzz is enabled, since the pref cant disable it if use system-harfbuzz ; then echo "sticky_pref(\"gfx.font_rendering.graphite.enabled\",true);" \ >>"${BUILD_OBJ_DIR}/dist/bin/browser/defaults/preferences/all-gentoo.js" || die fi # force cairo as the canvas renderer on platforms without skia support if [[ $(tc-endian) == "big" ]] ; then echo "sticky_pref(\"gfx.canvas.azure.backends\",\"cairo\");" \ >>"${BUILD_OBJ_DIR}/dist/bin/browser/defaults/preferences/all-gentoo.js" || die echo "sticky_pref(\"gfx.content.azure.backends\",\"cairo\");" \ >>"${BUILD_OBJ_DIR}/dist/bin/browser/defaults/preferences/all-gentoo.js" || die fi # Augment this with hwaccel prefs if use hwaccel ; then cat "${FILESDIR}"/gentoo-hwaccel-prefs.js-1 >> \ "${BUILD_OBJ_DIR}/dist/bin/browser/defaults/preferences/all-gentoo.js" \ || die fi if ! use screenshot ; then echo "pref(\"extensions.screenshots.disabled\", true);" >> \ "${BUILD_OBJ_DIR}/dist/bin/browser/defaults/preferences/all-gentoo.js" \ || die fi echo "pref(\"extensions.autoDisableScopes\", 3);" >> \ "${BUILD_OBJ_DIR}/dist/bin/browser/defaults/preferences/all-gentoo.js" \ || die if ! use gmp-autoupdate ; then local plugin for plugin in "${GMP_PLUGIN_LIST[@]}" ; do echo "pref(\"media.${plugin}.autoupdate\", false);" >> \ "${BUILD_OBJ_DIR}/dist/bin/browser/defaults/preferences/all-gentoo.js" \ || die done fi cd "${S}" MOZ_MAKE_FLAGS="${MAKEOPTS}" SHELL="${SHELL:-${EPREFIX}/bin/bash}" MOZ_NOSPAM=1 \ DESTDIR="${D}" ./mach install || die if use geckodriver ; then cp "${BUILD_OBJ_DIR}"/dist/bin/geckodriver "${ED%/}"${MOZILLA_FIVE_HOME} || die pax-mark m "${ED%/}"${MOZILLA_FIVE_HOME}/geckodriver dosym ${MOZILLA_FIVE_HOME}/geckodriver /usr/bin/geckodriver fi # Install language packs MOZEXTENSION_TARGET="distribution/extensions" MOZ_INSTALL_L10N_XPIFILE="1" mozlinguas_src_install local size sizes icon_path icon name if use bindist ; then sizes="16 32 48" icon_path="${S}/browser/branding/aurora" # Firefox's new rapid release cycle means no more codenames # Let's just stick with this one... icon="aurora" name="Aurora" # Override preferences to set the MOZ_DEV_EDITION defaults, since we # don't define MOZ_DEV_EDITION to avoid profile debaucles. # (source: browser/app/profile/firefox.js) cat >>"${BUILD_OBJ_DIR}/dist/bin/browser/defaults/preferences/all-gentoo.js" <=media-sound/apulse-0.1.9" ; then einfo "APULSE found - Generating library symlinks for sound support" local lib pushd "${ED}"${MOZILLA_FIVE_HOME} &>/dev/null || die for lib in ../apulse/libpulse{.so{,.0},-simple.so{,.0}} ; do # a quickpkg rolled by hand will grab symlinks as part of the package, # so we need to avoid creating them if they already exist. if [[ ! -L ${lib##*/} ]] ; then ln -s "${lib}" ${lib##*/} || die fi done popd &>/dev/null || die fi } pkg_postinst() { gnome2_icon_cache_update xdg_desktop_database_update if ! use gmp-autoupdate ; then elog "USE='-gmp-autoupdate' has disabled the following plugins from updating or" elog "installing into new profiles:" local plugin for plugin in "${GMP_PLUGIN_LIST[@]}" ; do elog "\t ${plugin}" done elog fi if use pulseaudio && has_version ">=media-sound/apulse-0.1.9" ; then elog "Apulse was detected at merge time on this system and so it will always be" elog "used for sound. If you wish to use pulseaudio instead please unmerge" elog "media-sound/apulse." elog fi local show_doh_information show_normandy_information if [[ -z "${REPLACING_VERSIONS}" ]] ; then # New install; Tell user that DoH is disabled by default show_doh_information=yes show_normandy_information=yes else local replacing_version for replacing_version in ${REPLACING_VERSIONS} ; do if ver_test "${replacing_version}" -lt 68.6.0-r3 ; then # Tell user only once about our DoH default show_doh_information=yes fi if ver_test "${replacing_version}" -lt 68.6.0-r3 ; then # Tell user only once about our Normandy default show_normandy_information=yes fi done fi if [[ -n "${show_doh_information}" ]] ; then elog elog "Note regarding Trusted Recursive Resolver aka DNS-over-HTTPS (DoH):" elog "Due to privacy concerns (encrypting DNS might be a good thing, sending all" elog "DNS traffic to Cloudflare by default is not a good idea and applications" elog "should respect OS configured settings), \"network.trr.mode\" was set to 5" elog "(\"Off by choice\") by default." elog "You can enable DNS-over-HTTPS in ${PN^}'s preferences." fi # bug 713782 if [[ -n "${show_normandy_information}" ]] ; then elog elog "Upstream operates a service named Normandy which allows Mozilla to" elog "push changes for default settings or even install new add-ons remotely." elog "While this can be useful to address problems like 'Armagadd-on 2.0' or" elog "revert previous decisions to disable TLS 1.0/1.1, privacy and security" elog "concerns prevail, which is why we have switched off the use of this" elog "service by default." elog elog "To re-enable this service set" elog elog " app.normandy.enabled=true" elog elog "in about:config." fi } pkg_postrm() { gnome2_icon_cache_update xdg_desktop_database_update }