aboutsummaryrefslogtreecommitdiff
path: root/network/PaleMoon/PaleMoon.SlackBuild
diff options
context:
space:
mode:
Diffstat (limited to 'network/PaleMoon/PaleMoon.SlackBuild')
-rw-r--r--network/PaleMoon/PaleMoon.SlackBuild213
1 files changed, 213 insertions, 0 deletions
diff --git a/network/PaleMoon/PaleMoon.SlackBuild b/network/PaleMoon/PaleMoon.SlackBuild
new file mode 100644
index 0000000000000..faee905112a80
--- /dev/null
+++ b/network/PaleMoon/PaleMoon.SlackBuild
@@ -0,0 +1,213 @@
+#!/bin/sh
+
+# Slackware build script for PaleMoon
+
+# Copyright 2016 Vasily Sora USA
+# All rights reserved.
+#
+# Redistribution and use of this script, with or without modification, is
+# permitted provided that the following conditions are met:
+#
+# 1. Redistributions of this script must retain the above copyright
+# notice, this list of conditions and the following disclaimer.
+#
+# THIS SOFTWARE IS PROVIDED BY THE AUTHOR "AS IS" AND ANY EXPRESS OR IMPLIED
+# WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+# MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
+# EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
+# PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
+# OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+# WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
+# OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
+# ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+# Modified by SlackBuilds.org
+
+PRGNAM=PaleMoon
+VERSION=${VERSION:-26.4.1}
+BUILD=${BUILD:-1}
+TAG=${TAG:-_SBo}
+
+if [ -z "$ARCH" ]; then
+ case "$( uname -m )" in
+ i?86) ARCH=i586 ;;
+ arm*) ARCH=arm ;;
+ *) ARCH=$( uname -m ) ;;
+ esac
+fi
+
+CWD=$(pwd)
+TMP=${TMP:-/tmp/SBo}
+PKG=$TMP/package-$PRGNAM
+OUTPUT=${OUTPUT:-/tmp}
+
+# You can try changing the optimization level to simply "-O2" if your processor
+# doesn't support sse2 instructions.
+# "-Os" might help if you experience segfaults.
+OPTIMIZE=${OPTIMIZE:-"-O2 -msse2 -mfpmath=sse"}
+if [ "$ARCH" = "i586" ]; then
+ SLKCFLAGS="-O2 -march=i586 -mtune=i686"
+ LIBDIRSUFFIX=""
+elif [ "$ARCH" = "i686" ]; then
+ SLKCFLAGS="-O2 -march=i686 -mtune=i686"
+ LIBDIRSUFFIX=""
+elif [ "$ARCH" = "x86_64" ]; then
+ SLKCFLAGS="-O2 -fPIC"
+ LIBDIRSUFFIX="64"
+else
+ SLKCFLAGS="-O2"
+ LIBDIRSUFFIX=""
+fi
+
+rm -rf $PKG $TMP/pmbuild $TMP/gold
+mkdir -p $TMP $PKG $OUTPUT $TMP/pmbuild $TMP/gold
+
+DEBUG=" --enable-strip --disable-debug --disable-debug-symbols "
+if [ "${ENABLE_DEBUG:-no}" = "yes" ]; then
+ DEBUG=" --disable-strip --disable-install-strip --enable-debug --enable-debug-symbols "
+ # On IA32, use gold since GNU ld runs out of memory linking libxul.so
+ # when debug is turned on
+ if [ "$ARCH" = "i586" -o "$ARCH" = "i686" ]; then
+ echo "#!/bin/bash" >> $TMP/gold/gold
+ echo "/usr/bin/ld.gold \"\$@\"" >> $TMP/gold/gold
+ cp $TMP/gold/gold $TMP/gold/ld
+ chmod +x $TMP/gold/*
+ PATH="$TMP/gold:$PATH"
+ export CC="gcc -B$TMP/gold"
+ export CXX="g++ -B$TMP/gold"
+ fi
+fi
+
+set -e
+
+# We need to use the incredibly ancient autoconf-2.13 for this :/
+# (Taken from Slackware's Firefox build Script)
+cd $TMP
+rm -rf autoconf-2.13
+tar xvf $CWD/autoconf-2.13.tar.xz
+cd autoconf-2.13
+zcat $CWD/autoconf-2.13-consolidated_fixes-1.patch.gz | patch -p1 --verbose
+chown -R root:root .
+find . \
+ \( -perm 777 -o -perm 775 -o -perm 711 -o -perm 555 -o -perm 511 \) \
+ -exec chmod 755 {} \; -o \
+ \( -perm 666 -o -perm 664 -o -perm 600 -o -perm 444 -o -perm 440 -o -perm 400 \) \
+ -exec chmod 644 {} \;
+
+# Build a temporary copy of autoconf-2.13 only to be used to compile
+# PaleMoon, since it somewhat inexplicably requires this ancient version:
+rm -rf $TMP/autoconf-tmp
+mkdir -p $TMP/autoconf-tmp
+# This will be at the beginning of the $PATH, so protect against nonsense
+# happening in $TMP:
+chmod 700 $TMP/autoconf-tmp
+rm -rf $TMP/autoconf-tmp/*
+mkdir -p $TMP/autoconf-tmp/usr
+
+./configure \
+ --prefix=$TMP/autoconf-tmp/usr \
+ --program-suffix=-2.13 \
+ --infodir=$TMP/autoconf-tmp/usr/info \
+ --mandir=$TMP/autoconf-tmp/usr/man \
+ --build=$ARCH-slackware-linux
+
+make || make -j1
+make install
+PATH=$TMP/autoconf-tmp/usr/bin:$PATH
+
+# Build palemoon
+cd $TMP
+rm -rf Pale-Moon-${VERSION}_Release
+tar xzvf $CWD/${VERSION}_Release.tar.gz
+cd Pale-Moon-${VERSION}_Release
+chown -R root:root .
+ find -L . \
+ \( -perm 777 -o -perm 775 -o -perm 750 -o -perm 711 -o -perm 555 \
+ -o -perm 511 \) -exec chmod 755 {} \; -o \
+ \( -perm 666 -o -perm 664 -o -perm 640 -o -perm 600 -o -perm 444 \
+ -o -perm 440 -o -perm 400 \) -exec chmod 644 {} \;
+
+# Crude hack so that /usr/lib/mozilla/plugins points to
+# /usr/lib64/mozilla/plugins on 64 bit systems
+if [ "$LIBDIRSUFFIX" = "64" ]; then
+ sed -i 's:/usr/lib/mozilla/plugins:/usr/lib64/mozilla/plugins:g' \
+ xpcom/io/nsAppFileLocationProvider.cpp
+else
+ echo "Oh, we're on a 32 bit system, nothing to do here!"
+fi
+
+export MOZBUILD_STATE_PATH="$TMP/Pale-Moon-${VERSION}_Release/moz.build"
+export MOZCONFIG="$TMP/Pale-Moon-${VERSION}_Release/.mozconfig"
+export MOZILLA_OFFICIAL=1
+export MOZ_MAKE_FLAGS=$MAKEFLAGS
+export CFLAGS="$SLKCFLAGS"
+export CXXFLAGS="$SLKCFLAGS"
+
+# Please see https://www.palemoon.org/redist.shtml for restrictions when using the official branding.
+# Our building options, in a configure-like display ;)
+OPTIONS="\
+ --enable-official-branding \
+ --enable-application=browser \
+ --disable-installer \
+ --disable-updater \
+ --disable-tests \
+ --disable-mochitests \
+ --enable-jemalloc \
+ --with-pthreads \
+ $DEBUG \
+ --x-libraries=/usr/lib${LIBDIRSUFFIX} \
+ --with-default-mozilla-five-home=/usr/lib${LIBDIRSUFFIX}/palemoon-$VERSION \
+ --prefix=/usr \
+ --sysconfdir=/etc \
+ --localstatedir=/var \
+ --mandir=/usr/man"
+
+echo "mk_add_options MOZ_CO_PROJECT=browser" >> .mozconfig
+echo "mk_add_options MOZ_OBJDIR=$TMP/pmbuild" >> .mozconfig
+
+# Write in the .mozconfig the options above
+for option in $OPTIONS; do echo "ac_add_options $option" >> .mozconfig; done
+echo "ac_add_options --enable-optimize=\"$OPTIMIZE\"" >> .mozconfig
+
+python2 mach build || echo "Next =>"
+python2 mach build
+
+cd $TMP/pmbuild
+make package
+
+cd dist
+
+mkdir -p $PKG/usr/bin
+mkdir -p $PKG/usr/share/icons/hicolor/{16x16,32x32,48x48,128x128}/apps
+mkdir -p $PKG/usr/share/applications
+mkdir -p $PKG/usr/lib${LIBDIRSUFFIX}
+
+# Install palemoon into /usr/lib${LIBDIRSUFFIX}
+cp -r palemoon $PKG/usr/lib${LIBDIRSUFFIX}/palemoon-$VERSION
+
+cd $PKG
+
+ln -s /usr/lib${LIBDIRSUFFIX}/palemoon-$VERSION/palemoon usr/bin/palemoon-$VERSION
+# Icons
+ln -s /usr/lib${LIBDIRSUFFIX}/palemoon-$VERSION/browser/chrome/icons/default/default16.png \
+ usr/share/icons/hicolor/16x16/apps/${PRGNAM}-$VERSION.png
+ln -s /usr/lib${LIBDIRSUFFIX}/chrome/icons/default/default32.png \
+ usr/share/icons/hicolor/32x32/apps/${PRGNAM}-$VERSION.png
+ln -s /usr/lib${LIBDIRSUFFIX}/chrome/icons/default/default48.png \
+ usr/share/icons/hicolor/48x48/apps/${PRGNAM}-$VERSION.png
+ln -s /usr/lib${LIBDIRSUFFIX}/palemoon-$VERSION/browser/icons/mozicon128.png \
+ usr/share/icons/hicolor/128x128/apps/${PRGNAM}-$VERSION.png
+
+# Install .desktop file
+sed "s|@VERSION@|$VERSION|" $CWD/$PRGNAM.desktop \
+ > $PKG/usr/share/applications/$PRGNAM.desktop
+
+mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION
+cat $CWD/$PRGNAM.SlackBuild > $PKG/usr/doc/$PRGNAM-$VERSION/$PRGNAM.SlackBuild
+
+mkdir -p $PKG/install
+cat $CWD/slack-desc > $PKG/install/slack-desc
+cat $CWD/doinst.sh > $PKG/install/doinst.sh
+
+/sbin/makepkg -l y -c n $OUTPUT/$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.${PKGTYPE:-tgz}