diff options
Diffstat (limited to 'system/virtualbox-ose/virtualbox-ose.SlackBuild')
-rw-r--r-- | system/virtualbox-ose/virtualbox-ose.SlackBuild | 210 |
1 files changed, 210 insertions, 0 deletions
diff --git a/system/virtualbox-ose/virtualbox-ose.SlackBuild b/system/virtualbox-ose/virtualbox-ose.SlackBuild new file mode 100644 index 0000000000..90b1faef35 --- /dev/null +++ b/system/virtualbox-ose/virtualbox-ose.SlackBuild @@ -0,0 +1,210 @@ +#!/bin/sh + +# Slackware build script for virtualbox-ose + +# Copyright 2008 Heinz Wiesinger <pprkut@liwjatan.at> +# Copyright 2008 Mauro Giachero <mauro.giachero@gmail.com> +# 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-ose +SRCNAM=VirtualBox +VERSION=2.0.6 +ARCH=${ARCH:-i486} +BUILD=${BUILD:-1} +TAG=${TAG:-_SBo} + +CWD=$(pwd) +TMP=${TMP:-/tmp/SBo} +PKG=$TMP/package-$PRGNAM +OUTPUT=${OUTPUT:-/tmp} + +# kmk doesn't support MAKEFLAGS, so we use JOBS here +JOBS=${JOBS:-3} + +# Define Variable Names +GUI="" +qtgui="" + +# Support for the pulseaudio-backend +if [ "${PULSE:-no}" = "no" ]; then + do_pulse="--disable-pulse" +else + do_pulse="" +fi + +# Using the vboxusers-group +VBOXUSERS=${VBOXUSERS:-yes} + +if [ "$VBOXUSERS" = "yes" ]; then + # Check for vboxusers group here + if ! grep ^vboxusers: /etc/group 2>&1 > /dev/null; then + echo " Must have a vboxusers group to run this script." + echo " # groupadd -g 215 vboxusers" + echo " Or something similar." + exit 1 + fi +fi + +# Enable Hardeing - Defaulting to yes as requested by upstream +if [ "${HARDENING:-yes}" = "yes" ]; then + harden="--enable-hardening" + VBOXUSERS="yes" +else + harden="--disable-hardening" +fi + +if [ "$ARCH" = "i486" ]; then + SLKCFLAGS="-O2 -march=i486 -mtune=i686" +elif [ "$ARCH" = "i686" ]; then + SLKCFLAGS="-O2 -march=i686 -mtune=i686" +elif [ "$ARCH" = "x86_64" ]; then + SLKCFLAGS="-O2 -fPIC" +fi + +set -e + +rm -rf $PKG +mkdir -p $TMP $PKG $OUTPUT +cd $TMP +rm -rf $SRCNAM-$VERSION +tar xvf $CWD/$SRCNAM-${VERSION}-OSE.tar.bz2 +cd $SRCNAM-$VERSION +patch -d src/VBox/Installer/linux -i $CWD/VBox.diff +chown -R root:root . +chmod -R u+w,go+r-w,a-s . + +# The Innotek init script tries to set the device nodes' permissions. +# This is problematic with VBOXUSERS=no, but you probably still want +# this for security reasons when using the vboxusers-group +if [ "$VBOXUSERS" = "yes" ]; then + GROUP="vboxusers" + MODE="750" + mkdir -p $PKG/etc/udev/rules.d + echo 'KERNEL=="vboxdrv", NAME="vboxdrv", OWNER="root", GROUP="vboxusers", MODE="0660"' \ + > $PKG/etc/udev/rules.d/60-vboxdrv.rules +else + patch -d src/VBox/Installer/linux -i $CWD/vboxdrv.sh.in.diff + GROUP="root" + MODE="755" + mkdir -p $PKG/etc/udev/rules.d + echo 'KERNEL=="vboxdrv", NAME="vboxdrv", MODE="0666"' \ + > $PKG/etc/udev/rules.d/60-vboxdrv.rules +fi + +# Support for the qt3-frontend +if [ "${QT3:-yes}" = "yes" ]; then + qtgui+=" --with-qt-dir=/usr/lib/qt" + GUI+=" VirtualBox3" + mkdir -p $PKG/usr/share/applications + cp -f $CWD/VirtualBox3.desktop $PKG/usr/share/applications/ + sed -i "s|\$VBOX_DOC_PATH|/usr/share/virtualbox|" \ + $PKG/usr/share/applications/VirtualBox3.desktop +else + qtgui+=" --disable-qt3" +fi + +# Support for the qt4-frontend +if [ "${QT4:-no}" = "no" ]; then + qtgui+=" --disable-qt4" +else + GUI+=" VirtualBox" + mkdir -p $PKG/usr/share/applications + cp -f src/VBox/Installer/linux/VirtualBox.desktop $PKG/usr/share/applications/ + sed -i "s|\$VBOX_DOC_PATH|/usr/share/virtualbox|" \ + $PKG/usr/share/applications/VirtualBox.desktop +fi + +cd src/VBox/Frontends/VirtualBox + sed -i "s/VirtualBox3_QT_TRANSLATIONS/VirtualBox_QT_TRANSLATIONS/" \ + Makefile.kmk +cd - + +CFLAGS="$SLKCFLAGS" \ +CXXFLAGS="$SLKCFLAGS" \ +./configure \ + --ose \ + $harden \ + $qtgui \ + $do_pulse + +. env.sh + +kmk -j ${JOBS} LOCALCFG=$CWD/LocalConfig.kmk + +mkdir -p $PKG/usr/{lib,share}/virtualbox \ + $PKG/usr/{bin,src} \ + $PKG/usr/share/pixmaps \ + $PKG/etc/{rc.d,vbox} + +cp -f src/VBox/Installer/linux/vboxnet.sh.in $PKG/etc/rc.d/rc.vboxnet.new +cp -f src/VBox/Installer/linux/vboxdrv.sh.in $PKG/etc/rc.d/rc.vboxdrv.new +cp -f $CWD/vbox.cfg $PKG/etc/vbox/vbox.cfg.new +install -m $MODE -g $GROUP src/VBox/Installer/linux/VBoxAddIF.sh $PKG/usr/lib/virtualbox/VBoxTap + +cd out/linux.x86/release/bin/ + rm -f vboxdrv.ko + mv VBox.png $PKG/usr/share/pixmaps/ + mv src $PKG/usr/src/vboxdrv-$VERSION + mv sdk nls* *.tar.gz $PKG/usr/share/virtualbox/ + install -m $MODE -g $GROUP VBoxSysInfo.sh $PKG/usr/share/virtualbox/ + install -m $MODE -g $GROUP VBoxTunctl $PKG/usr/bin/ + rm -f VoxSysInfo.sh VBoxTunctl + mv * $PKG/usr/lib/virtualbox/ + chown -R root:$GROUP $PKG/usr/lib/virtualbox/ + chmod -R $MODE $PKG/usr/lib/virtualbox/ + mv $PKG/usr/lib/virtualbox/VBox.sh $PKG/usr/lib/virtualbox/VBox +cd - + +for i in $GUI VBoxManage VBoxSDL VBoxHeadless VBoxVRDP; do + ln -s /usr/lib/virtualbox/VBox $PKG/usr/bin/$i ; +done + +for i in VBoxAddIF VBoxDeleteIF; do + ln -s /usr/lib/virtualbox/VBoxTap $PKG/usr/bin/$i +done + +ln -s /usr/lib/virtualbox/vditool $PKG/usr/bin/vditool + +if [ "$harden" = "--enable-hardening" ]; then + for i in $GUI VBoxSDL VBoxHeadless; do + chmod 4${MODE} $PKG/usr/lib/virtualbox/$i + done +fi + +if [ -e "$CWD/VBoxGuestAdditions_$VERSION.iso" ]; then + cp -f $CWD/VBoxGuestAdditions_$VERSION.iso \ + $PKG/usr/share/virtualbox/VBoxGuestAdditions.iso +fi + +if [ -e "$CWD/UserManual.pdf" ]; then + cp -f $CWD/UserManual.pdf \ + $PKG/usr/share/virtualbox/UserManual.pdf +fi + +mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION +cp -f COPYING COPYING.CDDL $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 + +cd $PKG +/sbin/makepkg -l y -c n $OUTPUT/$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.tgz |