diff options
author | Martin Schlemmer <azarah@gentoo.org> | 2005-09-25 23:33:03 +0000 |
---|---|---|
committer | Martin Schlemmer <azarah@gentoo.org> | 2005-09-25 23:33:03 +0000 |
commit | 589a8104fe772b044370fbd5b4c3e296864aea81 (patch) | |
tree | c6b038d9664321f58686be76f776ca1d9dd61f9e /www-client | |
parent | New release, GLSA105396. Use libart rather than cairo, bug #106713. Update (diff) | |
download | historical-589a8104fe772b044370fbd5b4c3e296864aea81.tar.gz historical-589a8104fe772b044370fbd5b4c3e296864aea81.tar.bz2 historical-589a8104fe772b044370fbd5b4c3e296864aea81.zip |
New release, GLSA105396. Use libart rather than cairo, bug #106713. Update
gtk2 and xft code from upstream to fix various freetype-2.1.9 issues
including printing non-latin. Same for the libart renderer code.
Package-Manager: portage-2.0.52-r1
Diffstat (limited to 'www-client')
-rw-r--r-- | www-client/mozilla/ChangeLog | 11 | ||||
-rw-r--r-- | www-client/mozilla/Manifest | 10 | ||||
-rw-r--r-- | www-client/mozilla/files/digest-mozilla-1.7.12 | 7 | ||||
-rw-r--r-- | www-client/mozilla/files/mozilla-1.7.12-gtk2xft-link-pangoxft.patch | 15 | ||||
-rw-r--r-- | www-client/mozilla/files/mozilla-1.7.12-libart-freetype.patch | 50 | ||||
-rw-r--r-- | www-client/mozilla/mozilla-1.7.12.ebuild | 407 |
6 files changed, 499 insertions, 1 deletions
diff --git a/www-client/mozilla/ChangeLog b/www-client/mozilla/ChangeLog index 9b1d510f12ce..b7a67915fcbd 100644 --- a/www-client/mozilla/ChangeLog +++ b/www-client/mozilla/ChangeLog @@ -1,6 +1,15 @@ # ChangeLog for www-client/mozilla # Copyright 2002-2005 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/www-client/mozilla/ChangeLog,v 1.74 2005/09/17 23:04:43 weeve Exp $ +# $Header: /var/cvsroot/gentoo-x86/www-client/mozilla/ChangeLog,v 1.75 2005/09/25 23:33:03 azarah Exp $ + +*mozilla-1.7.12 (25 Sep 2005) + + 25 Sep 2005; Martin Schlemmer <azarah@gentoo.org> + +files/mozilla-1.7.12-gtk2xft-link-pangoxft.patch, + +files/mozilla-1.7.12-libart-freetype.patch, +mozilla-1.7.12.ebuild: + New release, GLSA105396. Use libart rather than cairo, bug #106713. Update + gtk2 and xft code from upstream to fix various freetype-2.1.9 issues + including printing non-latin. Same for the libart renderer code. 17 Sep 2005; Jason Wever <weeve@gentoo.org> mozilla-1.7.11-r3.ebuild: Stable on SPARC wrt security bug #105396. diff --git a/www-client/mozilla/Manifest b/www-client/mozilla/Manifest index dd2065cb80aa..75f2375452aa 100644 --- a/www-client/mozilla/Manifest +++ b/www-client/mozilla/Manifest @@ -1,3 +1,6 @@ +-----BEGIN PGP SIGNED MESSAGE----- +Hash: SHA1 + MD5 1a242e5dd432f1fc4b5396b7593c1cb8 mozilla-1.7.10-r1.ebuild 12594 MD5 efb11836f2b5c8f484f743a401229c53 mozilla-1.7.11-r2.ebuild 12246 MD5 f2ceeaf27fc4010779fa83d3e6f52064 ChangeLog 51465 @@ -36,3 +39,10 @@ MD5 d0e52abf109fe61c4195f0cbf002ae18 files/google.src 706 MD5 e3c488f3226f61adbb11d6a73ae84209 files/icon/mozilla.desktop 153 MD5 6d52ff4ce4567db1cad08ea40157a65d files/icon/mozilla-icon.png 2350 MD5 068edb8c46e34027f9c3febc19656c70 files/1.3/mozilla-1.3-fix-RAW-target.patch 328 +-----BEGIN PGP SIGNATURE----- +Version: GnuPG v1.4.2 (GNU/Linux) + +iD4DBQFDNzQc1ZcsMnZjRyIRAhlJAJdangvrFd4qsaGV0W1TD9xeyyrzAJ9Y1/iP +fH6ydB20vp028W0mnPaEAw== +=SDd7 +-----END PGP SIGNATURE----- diff --git a/www-client/mozilla/files/digest-mozilla-1.7.12 b/www-client/mozilla/files/digest-mozilla-1.7.12 new file mode 100644 index 000000000000..93b4ddc41e35 --- /dev/null +++ b/www-client/mozilla/files/digest-mozilla-1.7.12 @@ -0,0 +1,7 @@ +MD5 f1ad6adbbc0510eb76d352c94c801fac mozilla-1.7.12-source.tar.bz2 30446836 +MD5 64ba4c6e3b52568468c4f6680ec7e679 ipc-1.1.3.tar.gz 102593 +MD5 50c369ce6d6fcb2d275cd30319a601ff enigmail-0.92.0.tar.gz 377123 +MD5 b4355a5746dde47cf0a7981df1dff998 moz_libart_lgpl-2.3.10p1.tar.bz2 103063 +MD5 7960994910bda4c14a52bc119f9ceefc mozilla-jslibmath-alpha.patch 625 +MD5 855fcb4f3e40bbcc608113ceb11e2ceb mozilla-1.7.12-gtk2xft.patch.bz2 40416 +MD5 a120cd14ade242622387f76875ca9c39 mozilla-1.7.10-nsplugins-v2.patch 1968 diff --git a/www-client/mozilla/files/mozilla-1.7.12-gtk2xft-link-pangoxft.patch b/www-client/mozilla/files/mozilla-1.7.12-gtk2xft-link-pangoxft.patch new file mode 100644 index 000000000000..3b2b58a549cf --- /dev/null +++ b/www-client/mozilla/files/mozilla-1.7.12-gtk2xft-link-pangoxft.patch @@ -0,0 +1,15 @@ +--- mozilla/configure.in.az 2005-09-26 00:07:40.000000000 +0200 ++++ mozilla/configure.in 2005-09-26 00:10:56.000000000 +0200 +@@ -3430,9 +3430,10 @@ + if test "$MOZ_ENABLE_XFT" + then + AC_DEFINE(MOZ_ENABLE_XFT) +- PKG_CHECK_MODULES(MOZ_XFT, xft) + if test "$MOZ_ENABLE_GTK2"; then +- PKG_CHECK_MODULES(_PANGOCHK, pango >= 1.1.0) ++ PKG_CHECK_MODULES(MOZ_XFT, xft pangoxft >= 1.1.0) ++ else ++ PKG_CHECK_MODULES(MOZ_XFT, xft) + fi + fi + diff --git a/www-client/mozilla/files/mozilla-1.7.12-libart-freetype.patch b/www-client/mozilla/files/mozilla-1.7.12-libart-freetype.patch new file mode 100644 index 000000000000..84392bd4acdf --- /dev/null +++ b/www-client/mozilla/files/mozilla-1.7.12-libart-freetype.patch @@ -0,0 +1,50 @@ +$NetBSD: patch-by,v 1.2 2004/07/05 14:22:42 taya Exp $ + +diff -ru ../Orig/mozilla/layout/svg/renderer/src/libart/nsSVGLibartGlyphMetricsFT.cpp ./layout/svg/renderer/src/libart/nsSVGLibartGlyphMetricsFT.cpp +--- ../Orig/mozilla/layout/svg/renderer/src/libart/nsSVGLibartGlyphMetricsFT.cpp 2004-03-19 10:36:16.000000000 +0900 ++++ ./layout/svg/renderer/src/libart/nsSVGLibartGlyphMetricsFT.cpp 2004-07-04 22:59:19.000000000 +0900 +@@ -155,15 +155,15 @@ + + static NS_NAMED_LITERAL_STRING(arial, "arial"); + nsSVGLibartGlyphMetricsFT::sFontAliases.Put(NS_LITERAL_STRING("helvetica"), +- &arial); ++ (nsDependentString *)&arial); + + static NS_NAMED_LITERAL_STRING(courier, "courier new"); + nsSVGLibartGlyphMetricsFT::sFontAliases.Put(NS_LITERAL_STRING("courier"), +- &courier); ++ (nsDependentString *)&courier); + + static NS_NAMED_LITERAL_STRING(times, "times new roman"); + nsSVGLibartGlyphMetricsFT::sFontAliases.Put(NS_LITERAL_STRING("times"), +- ×); ++ (nsDependentString *)×); + } + + void NS_FreeSVGLibartGlyphMetricsFTGlobals() +@@ -440,19 +440,19 @@ + return; + } + +- FTC_Image_Desc imageDesc; +- imageDesc.font.face_id=(void*)font_data.font_entry.get(); // XXX do we need to addref? ++ FTC_ImageType imageDesc; ++ imageDesc->face_id = (FTC_FaceID)font_data.font_entry.get(); // XXX do we need to addref? + float twipstopixel = GetTwipsToPixels(); + float scale = GetPixelScale(); +- imageDesc.font.pix_width = (int)((float)(font_data.font.size)*twipstopixel/scale); +- imageDesc.font.pix_height = (int)((float)(font_data.font.size)*twipstopixel/scale); +- imageDesc.image_type |= ftc_image_grays; ++ imageDesc->width = (int)((float)(font_data.font.size)*twipstopixel/scale); ++ imageDesc->height = (int)((float)(font_data.font.size)*twipstopixel/scale); ++ imageDesc->flags = 0; + + // get the face + nsresult rv; + FTC_Manager mgr; + nsSVGLibartFreetype::ft2->GetFTCacheManager(&mgr); +- rv = nsSVGLibartFreetype::ft2->ManagerLookupSize(mgr, &imageDesc.font, &mFace, nsnull); ++ rv = nsSVGLibartFreetype::ft2->ManagerLookupFace(mgr, imageDesc->face_id, &mFace); + NS_ASSERTION(mFace, "failed to get face/size"); + } + diff --git a/www-client/mozilla/mozilla-1.7.12.ebuild b/www-client/mozilla/mozilla-1.7.12.ebuild new file mode 100644 index 000000000000..d018e90811d9 --- /dev/null +++ b/www-client/mozilla/mozilla-1.7.12.ebuild @@ -0,0 +1,407 @@ +# Copyright 1999-2005 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/www-client/mozilla/mozilla-1.7.12.ebuild,v 1.1 2005/09/25 23:33:03 azarah Exp $ + +unset ALLOWED_FLAGS # Stupid extra-functions.sh ... bug 49179 +MOZ_FREETYPE2="no" # Need to disable for newer .. remove here and in mozconfig + # when older is removed from tree. +inherit flag-o-matic toolchain-funcs eutils mozconfig mozilla-launcher makeedit multilib + +EMVER="0.92.0" +IPCVER="1.1.3" +SVGVER="2.3.10p1" + +# handle _rc versions +MY_PV=${PV/_alpha/a} # handle alpha +MY_PV=${MY_PV/_beta/b} # handle beta +MY_PV=${MY_PV/_rc/rc} # handle rc + +DESCRIPTION="Mozilla Application Suite - web browser, email, HTML editor, IRC" +HOMEPAGE="http://www.mozilla.org" +SRC_URI="http://ftp.mozilla.org/pub/mozilla.org/mozilla/releases/${PN}${MY_PV}/source/${PN}-${MY_PV}-source.tar.bz2 + crypt? ( !moznomail? ( + http://www.mozilla-enigmail.org/downloads/src/ipc-${IPCVER}.tar.gz + http://www.mozilla-enigmail.org/downloads/src/enigmail-${EMVER}.tar.gz + ) ) + mozsvg? ( + mirror://gentoo/moz_libart_lgpl-${SVGVER}.tar.bz2 + http://dev.gentoo.org/~azarah/mozilla/moz_libart_lgpl-${SVGVER}.tar.bz2 + ) + mirror://gentoo/mozilla-jslibmath-alpha.patch + mirror://gentoo/mozilla-1.7.12-gtk2xft.patch.bz2 + http://dev.gentoo.org/~azarah/mozilla/mozilla-1.7.12-gtk2xft.patch.bz2 + http://dev.gentoo.org/~agriffis/dist/mozilla-1.7.10-nsplugins-v2.patch" +# mozsvg? ( http://dev.gentoo.org/~azarah/mozilla/moz_libart_lgpl-${SVGVER}.tar.bz2 ) + +KEYWORDS="~alpha ~amd64 ~hppa ~ia64 ~ppc ~ppc64 ~sparc ~x86" +SLOT="0" +LICENSE="MPL-1.1 NPL-1.1" +IUSE="crypt gnome java ldap mozcalendar mozdevelop moznocompose moznoirc moznomail mozsvg postgres ssl" + +# xrender.pc appeared for the first time in xorg-x11-6.7.0-r2 +# and is required to build with support for cairo. #71504 +RDEPEND="java? ( virtual/jre ) + mozsvg? ( !<x11-base/xorg-x11-6.7.0-r2 ) + crypt? ( !moznomail? ( >=app-crypt/gnupg-1.2.1 ) ) + >=www-client/mozilla-launcher-1.42" + +DEPEND="${RDEPEND} + ~sys-devel/autoconf-2.13 + java? ( >=dev-java/java-config-0.2.0 ) + dev-lang/perl + postgres? ( >=dev-db/postgresql-7.2.0 )" + +S=${WORKDIR}/mozilla + +# Needed by src_compile() and src_install(). +# Would do in pkg_setup but that loses the export attribute, they +# become pure shell variables. +# +# NB: We can't export these vars until enigmail is installed separately instead +# of integrated into this ebuild. +# +#export BUILD_OFFICIAL=1 +#export MOZILLA_OFFICIAL=1 + +src_unpack() { + unpack mozilla-${MY_PV}-source.tar.bz2 + cd ${S} || die + + # Unpack the enigmail plugin + if use crypt && ! use moznomail; then + cd ${S}/extensions || die + unpack ipc-${IPCVER}.tar.gz enigmail-${EMVER}.tar.gz + for x in ipc enigmail; do + cd ${S}/extensions/${x} || die "cd failed" + makemake # from mozconfig.eclass + done + fi + if use mozsvg; then + cd ${S}/other-licenses + unpack moz_libart_lgpl-${SVGVER}.tar.bz2 + fi + cd ${S} + + #################################### + # + # architecture patches + # + #################################### + + if [[ $(gcc-major-version) -eq 3 ]]; then + # ABI Patch for alpha/xpcom for gcc-3.x + if [[ ${ARCH} == alpha ]]; then + epatch ${FILESDIR}/${PN}-alpha-xpcom-subs-fix.patch + fi + fi + + # HPPA patches from Ivar <orskaug@stud.ntnu.no> + # <gmsoft@gentoo.org> (22 Dec 2004) + epatch ${FILESDIR}/mozilla-hppa.patch + + # patch to fix math operations on alpha, makes maps.google.com work! + epatch ${DISTDIR}/mozilla-jslibmath-alpha.patch + + # Patch to allow compilation on ppc64 - bug #54843 + use ppc64 && epatch ${FILESDIR}/mozilla-1.7.6-ppc64.patch + + # Fix building on amd64 with gcc4 (patch from Debian) + epatch ${FILESDIR}/${PN}-1.7.8-amd64.patch + + #################################### + # + # general compilation and run-time fixes + # + #################################### + + # GCC4 compile fix, bug #87800 + epatch ${FILESDIR}/${PN}-1.7.6-gcc4.patch + + # Fix stack growth logic + epatch ${FILESDIR}/${PN}-stackgrowth.patch + + # Rather use gtk2+xft than freetype for font rendering, and add patch + # from mozilla bugzilla to improve printing. + # https://bugzilla.mozilla.org/show_bug.cgi?id=215219#c113 + epatch ${DISTDIR}/mozilla-1.7.12-gtk2xft.patch.bz2 + # Fix for above + epatch ${FILESDIR}/mozilla-1.7.12-gtk2xft-link-pangoxft.patch + + # Fix libart SVG renderer building against newer freetype2 + epatch ${FILESDIR}/mozilla-1.7.12-libart-freetype.patch + + #################################### + # + # behavioral fixes + # + #################################### + + # Mozilla Bug 292257, https://bugzilla.mozilla.org/show_bug.cgi?id=292257 + # Mozilla crashes under some rare cases when plugin.default_plugin_disabled + # is true. This patch fixes that. Backported by hansmi@gentoo.org. + epatch ${FILESDIR}/${PN}-1.7.8-objectframefix.diff + + # Fix scripts that call for /usr/local/bin/perl #51916 + ebegin "Patching smime to call perl from /usr/bin" + sed -i -e '1s,usr/local/bin,usr/bin,' security/nss/cmd/smimetools/smime + eend $? || die "sed failed" + + # look in /usr/lib/nsplugins for plugins, in addition to the usual places + epatch ${DISTDIR}/mozilla-1.7.10-nsplugins-v2.patch + + #################################### + # + # security fixes + # + #################################### + + # Needed by some of the patches + WANT_AUTOCONF=2.1 autoconf || die "WANT_AUTOCONF failed" +} + +src_compile() { + declare MOZILLA_FIVE_HOME=/usr/$(get_libdir)/${PN} + declare x + + #################################### + # + # mozconfig, CFLAGS and CXXFLAGS setup + # + #################################### + + mozconfig_init + + # Bug 60668: Galeon doesn't build without oji enabled, so enable it + # regardless of java setting. + mozconfig_annotate '' --enable-oji --enable-mathml + + # Other moz-specific settings + mozconfig_use_enable mozdevelop jsd + mozconfig_use_enable mozdevelop xpctools + mozconfig_use_extension mozdevelop venkman + mozconfig_use_enable gnome gnomevfs + mozconfig_use_extension gnome gnomevfs + mozconfig_use_extension !moznoirc irc + mozconfig_use_extension postgres sql + if use postgres ; then + export MOZ_ENABLE_PGSQL=1 + export MOZ_PGSQL_INCLUDES=/usr/include + export MOZ_PGSQL_LIBS=/usr/$(get_libdir) + fi + mozconfig_use_enable mozcalendar calendar + mozconfig_use_enable ldap + mozconfig_use_enable ldap ldap-experimental + mozconfig_use_enable mozsvg svg + mozconfig_use_enable mozsvg svg-renderer-libart + use mozsvg && export MOZ_INTERNAL_LIBART_LGPL=1 + mozconfig_annotate '' --with-default-mozilla-five-home=${MOZILLA_FIVE_HOME} + mozconfig_annotate '' --with-user-appdir=.mozilla + + if use moznomail && ! use mozcalendar; then + mozconfig_annotate "+moznomail -mozcalendar" --disable-mailnews + fi + if use moznocompose && use moznomail; then + mozconfig_annotate "+moznocompose +moznomail" --disable-composer + fi + + # Finalize and report settings + mozconfig_final + + # hardened GCC uses -fstack-protector-all by default, which breaks us + has_hardened && append-flags -fno-stack-protector-all + replace-flags -fstack-protector-all -fstack-protector + + #################################### + # + # Configure and build + # + #################################### + + CPPFLAGS="${CPPFLAGS} -DARON_WAS_HERE" \ + CC="$(tc-getCC)" CXX="$(tc-getCXX)" LD="$(tc-getLD)" \ + econf || die + + # It would be great if we could pass these in via CPPFLAGS or CFLAGS prior + # to econf, but the quotes cause configure to fail. + sed -i -e \ + 's|-DARON_WAS_HERE|-DGENTOO_NSPLUGINS_DIR=\\\"/usr/'"$(get_libdir)"'/nsplugins\\\" -DGENTOO_NSBROWSER_PLUGINS_DIR=\\\"/usr/'"$(get_libdir)"'/nsbrowser/plugins\\\"|' \ + ${S}/config/autoconf.mk \ + ${S}/nsprpub/config/autoconf.mk \ + ${S}/xpfe/global/buildconfig.html + + # This removes extraneous CFLAGS from the Makefiles to reduce RAM + # requirements while compiling + edit_makefiles + + emake || die + + #################################### + # + # Build Mozilla NSS + # + #################################### + + # Build the NSS/SSL support + if use ssl; then + einfo "Building Mozilla NSS..." + + # Fix #include problem + cd ${S}/security/coreconf || die "cd coreconf failed" + echo 'INCLUDES += -I$(DIST)/include/nspr -I$(DIST)/include/dbm'\ + >>headers.mk + emake -j1 || die "make security headers failed" + + cd ${S}/security/nss || die "cd nss failed" + emake -j1 moz_import || die "make moz_import failed" + emake -j1 || die "make nss failed" + fi + + #################################### + # + # Build Enigmail extension + # + #################################### + + if use crypt && ! use moznomail; then + for x in ipc enigmail; do + emake -C ${S}/extensions/${x} || die "emake ${x} failed" + done + fi +} + +src_install() { + declare MOZILLA_FIVE_HOME=/usr/$(get_libdir)/${PN} + + # Most of the installation happens here + dodir ${MOZILLA_FIVE_HOME} + cp -RL ${S}/dist/bin/* ${D}${MOZILLA_FIVE_HOME} + + # Create directory structure to support portage-installed extensions. + # See update_chrome() in mozilla-launcher + keepdir ${MOZILLA_FIVE_HOME}/chrome.d + keepdir ${MOZILLA_FIVE_HOME}/extensions.d + cp ${D}${MOZILLA_FIVE_HOME}/chrome/installed-chrome.txt \ + ${D}${MOZILLA_FIVE_HOME}/chrome.d/0_base-chrome.txt + + # Create /usr/bin/mozilla + install_mozilla_launcher_stub mozilla ${MOZILLA_FIVE_HOME} + + # Install icon and .desktop for menu entry + insinto /usr/share/pixmaps + doins ${FILESDIR}/icon/mozilla-icon.png + + # Fix bug 54179: Install .desktop file into /usr/share/applications + # instead of /usr/share/gnome/apps/Internet (18 Jun 2004 agriffis) + insinto /usr/share/applications + doins ${FILESDIR}/icon/mozilla.desktop + + # Fix icons to look the same everywhere + insinto ${MOZILLA_FIVE_HOME}/icons + doins ${S}/widget/src/gtk/mozicon16.xpm + doins ${S}/widget/src/gtk/mozicon50.xpm + + #################################### + # + # Install files necessary for applications to build against mozilla + # + #################################### + + einfo "Installing includes and idl files..." + dodir ${MOZILLA_FIVE_HOME}/include/idl /usr/include + cd ${S}/dist + cp -LfR include/* ${D}${MOZILLA_FIVE_HOME}/include + cp -LfR idl/* ${D}${MOZILLA_FIVE_HOME}/include/idl + + # Install the NSS/SSL libs, headers and tools + if use ssl; then + einfo "Installing Mozilla NSS..." + # Install the headers ('make install' do not work for headers ...) + insinto ${MOZILLA_FIVE_HOME}/include/nss + [ -d ${S}/dist/public/nss ] && doins ${S}/dist/public/nss/*.h + [ -d ${S}/dist/public/seccmd ] && doins ${S}/dist/public/seccmd/*.h + [ -d ${S}/dist/public/security ] && doins ${S}/dist/public/security/*.h + # These come with zlib ... + rm -f ${D}${MOZILLA_FIVE_HOME}/include/nss/{zconf.h,zlib.h} + + cd ${S}/security/nss + + mkdir -p ${WORKDIR}/nss/{bin,lib} + export SOURCE_BIN_DIR=${WORKDIR}/nss/bin + export SOURCE_LIB_DIR=${WORKDIR}/nss/lib + + make install || die "make failed" + # Gets installed as symbolic links ... + cp -Lf ${WORKDIR}/nss/bin/* ${D}/usr/bin + cp -Lf ${WORKDIR}/nss/lib/* ${D}${MOZILLA_FIVE_HOME} + + # Need to unset these incase we want to rebuild, else the build + # gets newked. + unset SOURCE_LIB_DIR + unset SOURCE_BIN_DIR + fi + + # Fix mozilla-config and install it + sed -i -e "s|/usr/lib/mozilla-${MY_PV}|${MOZILLA_FIVE_HOME}|g + s|/usr/include/mozilla-${MY_PV}|${MOZILLA_FIVE_HOME}/include|g" \ + ${S}/build/unix/mozilla-config + exeinto ${MOZILLA_FIVE_HOME} + doexe ${S}/build/unix/mozilla-config + + # Fix pkgconfig files and install them + insinto /usr/$(get_libdir)/pkgconfig + for x in ${S}/build/unix/*.pc; do + sed -i -e "s|^libdir=.*|libdir=${MOZILLA_FIVE_HOME}| + s|^includedir=.*|includedir=${MOZILLA_FIVE_HOME}/include|" ${x} + doins ${x} + done + + # Install env.d snippet, which isn't necessary for running mozilla, but + # might be necessary for programs linked against firefox + insinto /etc/env.d + doins ${FILESDIR}/10mozilla + dosed "s|/usr/lib|/usr/$(get_libdir)|" /etc/env.d/10mozilla + + # Install rebuild script since mozilla-bin doesn't support registration yet + exeinto ${MOZILLA_FIVE_HOME} + doexe ${FILESDIR}/mozilla-rebuild-databases.pl + + # Install docs + dodoc LEGAL LICENSE + + # Update Google search plugin to use UTF8 charset ... + insinto ${MOZILLA_FIVE_HOME}/searchplugins + doins ${FILESDIR}/google.src +} + +pkg_preinst() { + declare MOZILLA_FIVE_HOME=/usr/$(get_libdir)/${PN} + + # Remove entire installed instance to solve various problems, + # for example see bug 27719 + rm -rf ${ROOT}${MOZILLA_FIVE_HOME} +} + +pkg_postinst() { + declare MOZILLA_FIVE_HOME=/usr/$(get_libdir)/${PN} + + # Update the component registry + MOZILLA_LIBDIR=${ROOT}${MOZILLA_FIVE_HOME} MOZILLA_LAUNCHER=mozilla \ + /usr/libexec/mozilla-launcher -register + + # This should be called in the postinst and postrm of all the + # mozilla, mozilla-bin, firefox, firefox-bin, thunderbird and + # thunderbird-bin ebuilds. + update_mozilla_launcher_symlinks +} + +pkg_postrm() { + declare MOZILLA_FIVE_HOME=/usr/$(get_libdir)/${PN} + + # Update the component registry + if [[ -x ${MOZILLA_FIVE_HOME}/mozilla-bin ]]; then + MOZILLA_LIBDIR=${ROOT}${MOZILLA_FIVE_HOME} MOZILLA_LAUNCHER=mozilla \ + /usr/libexec/mozilla-launcher -register + fi + + update_mozilla_launcher_symlinks +} |