diff options
author | Heinz Wiesinger <pprkut@slackbuilds.org> | 2011-04-03 20:53:35 +0200 |
---|---|---|
committer | Robby Workman <rworkman@slackbuilds.org> | 2011-04-05 18:54:18 -0500 |
commit | 04e8c0f66a171c8f4dd25303f1bcc0b22c5099be (patch) | |
tree | b2adb8b2f26272ebd45cca7129087c9d3df46938 /system/virtualbox-addons/virtualbox-addons.SlackBuild | |
parent | 55e35b855ca231957b814320d2328656358b56a1 (diff) |
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.SlackBuild | 165 |
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 0000000000000..6dbf9d155cd71 --- /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} |