summaryrefslogtreecommitdiff
path: root/system/virtualbox-addons/virtualbox-addons.SlackBuild
diff options
context:
space:
mode:
authorHeinz Wiesinger <pprkut@slackbuilds.org>2011-04-03 20:53:35 +0200
committerRobby Workman <rworkman@slackbuilds.org>2011-04-05 18:54:18 -0500
commit04e8c0f66a171c8f4dd25303f1bcc0b22c5099be (patch)
treeb2adb8b2f26272ebd45cca7129087c9d3df46938 /system/virtualbox-addons/virtualbox-addons.SlackBuild
parent55e35b855ca231957b814320d2328656358b56a1 (diff)
downloadslackbuilds-04e8c0f66a171c8f4dd25303f1bcc0b22c5099be.tar.gz
system/virtualbox-addons: Renamed from virtualbox-ose-addons and updated for version 4.0.4
Signed-off-by: Heinz Wiesinger <pprkut@slackbuilds.org>
Diffstat (limited to 'system/virtualbox-addons/virtualbox-addons.SlackBuild')
-rw-r--r--system/virtualbox-addons/virtualbox-addons.SlackBuild165
1 files changed, 165 insertions, 0 deletions
diff --git a/system/virtualbox-addons/virtualbox-addons.SlackBuild b/system/virtualbox-addons/virtualbox-addons.SlackBuild
new file mode 100644
index 0000000000..6dbf9d155c
--- /dev/null
+++ b/system/virtualbox-addons/virtualbox-addons.SlackBuild
@@ -0,0 +1,165 @@
+#!/bin/sh
+
+# Slackware build script for virtualbox-ose-addons
+
+# Copyright 2008-2011 Heinz Wiesinger, Amsterdam, The Netherlands
+# 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.
+
+PRGNAM=virtualbox-addons
+SRCNAM=VirtualBox
+VERSION=4.0.4
+BUILD=${BUILD:-1}
+TAG=${TAG:-_SBo}
+
+if [ -z "$ARCH" ]; then
+ case "$( uname -m )" in
+ i?86) ARCH=i486 ;;
+ arm*) ARCH=arm ;;
+ *) ARCH=$( uname -m ) ;;
+ esac
+fi
+
+CWD=$(pwd)
+TMP=${TMP:-/tmp/SBo}
+PKG=$TMP/package-$PRGNAM
+OUTPUT=${OUTPUT:-/tmp}
+
+if ! grep ^vboxadd: /etc/passwd 2>&1 > /dev/null; then
+ echo " You must have a vboxadd user to run this script."
+ echo " # useradd -u 215 -d /var/run/vboxadd -g 1 -s /bin/sh vboxadd"
+ exit 1
+fi
+
+# kmk doesn't support MAKEFLAGS, so we use JOBS here
+JOBS=${JOBS:-3}
+
+# set xorg-server version
+XSERVER=$(X -version 2>&1 | grep Server | cut -d " " -f 4 | sed "s/\.//" | cut -d "." -f 1)
+
+if [ "$ARCH" = "i486" ]; then
+ SLKCFLAGS="-O2 -march=i486 -mtune=i686"
+ LIBDIRSUFFIX=""
+ TARGET="x86"
+elif [ "$ARCH" = "i686" ]; then
+ SLKCFLAGS="-O2 -march=i686 -mtune=i686"
+ LIBDIRSUFFIX=""
+ TARGET="x86"
+elif [ "$ARCH" = "x86_64" ]; then
+ SLKCFLAGS="-O2 -fPIC"
+ LIBDIRSUFFIX="64"
+ TARGET="amd64"
+fi
+
+set -e
+
+rm -rf $PKG
+mkdir -p $TMP $PKG $OUTPUT
+cd $TMP
+rm -rf $SRCNAM-${VERSION}_OSE
+tar xvf $CWD/$SRCNAM-${VERSION}.tar.bz2
+cd $SRCNAM-${VERSION}_OSE
+chown -R root:root .
+chmod -R u+w,go+r-w,a-s .
+
+# We set the environment variables manually to avoid dependency on acpica
+export BUILD_PLATFORM="linux"
+export BUILD_PLATFORM_ARCH="$TARGET"
+export BUILD_TARGET="linux"
+export BUILD_TARGET_ARCH="$TARGET"
+export BUILD_TARGET_CPU="$ARCH"
+export BUILD_TYPE="release"
+export PATH_KBUILD="$TMP/$SRCNAM-${VERSION}_OSE/kBuild"
+export PATH_DEVTOOLS="$TMP/$SRCNAM-${VERSION}_OSE/tools"
+path_kbuild_bin="$PATH_KBUILD/bin/$BUILD_TARGET.$BUILD_PLATFORM_ARCH"
+export PATH_KBUILD_BIN="$path_kbuild_bin"
+path_dev_bin="$PATH_DEVTOOLS/$BUILD_TARGET.$BUILD_PLATFORM_ARCH"/bin
+echo "$PATH" | grep -q "$path_kbuild_bin" || PATH="$path_kbuild_bin:$PATH"
+echo "$PATH" | grep -q "$path_dev_bin" || PATH="$path_dev_bin:$PATH"
+export PATH
+unset path_kbuild_bin path_dev_bin
+
+kmk -j ${JOBS} LOCALCFG=$CWD/LocalConfig.kmk
+
+mkdir -p $PKG/lib/udev/rules.d $PKG/sbin \
+ $PKG/etc/{xdg/autostart,rc.d,X11/xorg.conf.d} \
+ $PKG/usr/{src,bin,sbin,share/autostart} \
+ $PKG/usr/lib$LIBDIRSUFFIX/xorg/modules/{drivers,input}
+
+patch -d src/VBox/Additions/linux/installer/ -i $CWD/rc.vboxadd.diff
+cp -f src/VBox/Additions/linux/installer/vboxadd.sh \
+ $PKG/etc/rc.d/rc.vboxadd.new
+cp -f src/VBox/Additions/linux/installer/vboxadd-service.sh \
+ $PKG/etc/rc.d/rc.vboxadd-service.new
+
+cp -f src/VBox/Additions/x11/Installer/vboxclient.desktop \
+ $PKG/etc/xdg/autostart/
+cp -f src/VBox/Additions/x11/Installer/vboxclient.desktop \
+ $PKG/usr/share/autostart/
+install -m 755 src/VBox/Additions/x11/Installer/98vboxadd-xclient \
+ $PKG/usr/bin/VBoxClient-all
+
+echo "KERNEL==\"vboxguest\", NAME=\"vboxguest\", OWNER=\"vboxadd\", MODE=\"0660\"" \
+ > $PKG/lib/udev/rules.d/60-vboxadd.rules
+echo "KERNEL==\"vboxuser\", NAME=\"vboxuser\", OWNER=\"vboxadd\", MODE=\"0666\"" \
+ >> $PKG/lib/udev/rules.d/60-vboxadd.rules
+
+install -m 644 src/VBox/Additions/linux/installer/70-xorg-vboxmouse.rules \
+ $PKG/lib/udev/rules.d/
+
+install -m 644 src/VBox/Additions/x11/Installer/50-vboxmouse.conf \
+ $PKG/etc/X11/xorg.conf.d/
+
+cd out/linux.$TARGET/release/bin/additions
+ cp -rf src/vboxguest $PKG/usr/src/vboxguest-$VERSION
+ cp -rf src/vboxsf $PKG/usr/src/vboxsf-$VERSION
+ cp -rf src/vboxvideo $PKG/usr/src/vboxvideo-$VERSION
+ install -m 755 VBoxControl $PKG/usr/bin/
+ install -m 755 VBoxClient $PKG/usr/bin/
+ install -m 755 VBoxService $PKG/usr/sbin/
+ install -m 4755 mount.vboxsf $PKG/sbin/mount.vboxsf
+ install -m 644 vboxvideo_drv_$XSERVER.so \
+ $PKG/usr/lib$LIBDIRSUFFIX/xorg/modules/drivers/vboxvideo_drv.so
+ install -m 644 vboxmouse_drv_$XSERVER.so \
+ $PKG/usr/lib$LIBDIRSUFFIX/xorg/modules/input/vboxmouse_drv.so
+
+ install -m 644 VBoxOGLcrutil.so $PKG/usr/lib$LIBDIRSUFFIX
+ install -m 644 VBoxOGLerrorspu.so $PKG/usr/lib$LIBDIRSUFFIX
+ install -m 644 VBoxOGLarrayspu.so $PKG/usr/lib$LIBDIRSUFFIX
+ install -m 644 VBoxOGLfeedbackspu.so $PKG/usr/lib$LIBDIRSUFFIX
+ install -m 644 VBoxOGLpackspu.so $PKG/usr/lib$LIBDIRSUFFIX
+ install -m 644 VBoxOGLpassthroughspu.so $PKG/usr/lib$LIBDIRSUFFIX
+ install -m 644 VBoxOGL.so $PKG/usr/lib$LIBDIRSUFFIX
+
+ mkdir -p $PKG/usr/lib$LIBDIRSUFFIX/xorg/modules/dri
+ ln -s /usr/lib$LIBDIRSUFFIX/VBoxOGL.so \
+ $PKG/usr/lib$LIBDIRSUFFIX/xorg/modules/dri/vboxvideo_dri.so
+cd -
+
+mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION
+cp -f COPYING COPYING.CDDL $PKG/usr/doc/$PRGNAM-$VERSION
+cat $CWD/README.SLACKWARE > $PKG/usr/doc/$PRGNAM-$VERSION/README.SLACKWARE
+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
+
+cd $PKG
+/sbin/makepkg -l y -c n $OUTPUT/$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.${PKGTYPE:-tgz}