summaryrefslogtreecommitdiffstats
path: root/vde/build
diff options
context:
space:
mode:
author Eric Hameleers <alien@slackware.com>2005-07-05 07:31:40 +0000
committer Eric Hameleers <alien@slackware.com>2005-07-05 07:31:40 +0000
commit4207ffa60579978a3552707188e603cfa0f27310 (patch)
tree8640996b9d682f0adb5a4125f094dcd0be0a3aea /vde/build
parentb74237d08a1152aed490b0b9245ae6c84da3d723 (diff)
downloadasb-4207ffa60579978a3552707188e603cfa0f27310.tar.gz
asb-4207ffa60579978a3552707188e603cfa0f27310.tar.xz
Initial revision
Diffstat (limited to 'vde/build')
-rwxr-xr-xvde/build/get_URL.sh36
-rwxr-xr-xvde/build/vde.SlackBuild176
2 files changed, 212 insertions, 0 deletions
diff --git a/vde/build/get_URL.sh b/vde/build/get_URL.sh
new file mode 100755
index 00000000..d5ca952f
--- /dev/null
+++ b/vde/build/get_URL.sh
@@ -0,0 +1,36 @@
+#!/bin/sh
+# $Id$
+# ---------------------------------------------------------------------------
+# Download a software tarball.
+# The script tries to determine the version to be downloaded in two ways:
+# 1: is it supplied as a parameter?
+# 2: is it found in the corresponding SlackBuild script?
+#
+# If the tarball is already present, do not download again.
+#
+
+PRGNAM=vde
+
+VERSION=$1
+
+URL='http://belnet.dl.sourceforge.net/sourceforge/vde/${PRGNAM}-${VERSION}.tgz'
+
+if [ "$VERSION" == "" ]; then
+ [ -s ${PRGNAM}.SlackBuild ] && eval `grep "^VERSION=" ${PRGNAM}.SlackBuild`
+ if [ "$VERSION" == "" ]; then
+ echo "Must supply version number as parameter !"
+ exit 1
+ fi
+fi
+
+if [ -s `basename \`echo $(eval echo \$URL)\`` ]; then
+ echo "File `basename \`echo $(eval echo \$URL)\`` already present!"
+ exit 1
+else
+ echo "File `basename \`echo $(eval echo \$URL)\`` not yet present locally!"
+fi
+
+echo "Getting ${PRGNAM} (version ${VERSION}) at `echo $(eval echo $URL)`"
+#curl `echo $(eval echo $URL)` -o `basename \`echo $(eval echo \$URL)\``
+wget -nv `echo $(eval echo $URL)`
+
diff --git a/vde/build/vde.SlackBuild b/vde/build/vde.SlackBuild
new file mode 100755
index 00000000..ca3f5814
--- /dev/null
+++ b/vde/build/vde.SlackBuild
@@ -0,0 +1,176 @@
+#!/bin/sh
+#
+# -----------------------------------------------------------------------------
+#
+# Slackware SlackBuild script
+# ===========================
+# By: Eric Hameleers
+# Created: 16dec2004
+# For: vde
+# URL: http://vde.sourceforge.net/
+# Needs:
+# Changelog:
+# 1.5.7-1: 16/dec/2004 by Eric Hameleers
+# * Initial build.
+# 1.5.7-2: 18/dec/2004 by Eric Hameleers
+# * Added uml README to the documentation
+# 1.5.7-3: 08/feb/2005 by Eric Hameleers
+# * Fixed incorrect link for vdeqemu; added rc.vdenetwork which
+# sets up the right environment for qemu, using dnsmasq.
+# If you already run a local nameserver, you'll have to edit out
+# parts of that file.
+#
+#
+# Run 'sh SlackBuild --cleanup' to build a Slackware package.
+# The package (.tgz) plus descriptive .txt file are created in /tmp .
+# Install using 'installpkg'.
+#
+# -----------------------------------------------------------------------------
+
+# --- INIT ---
+# Set initial variables:
+CWD=`pwd`
+if [ "$TMP" = "" ]; then
+ TMP=/tmp
+fi
+
+PRGNAM=vde
+VERSION=1.5.7
+ARCH=${ARCH:-i486}
+BUILD=3
+
+if [ "$ARCH" = "i386" ]; then
+ SLKCFLAGS="-O2 -march=i386 -mcpu=i686"
+elif [ "$ARCH" = "i486" ]; then
+ SLKCFLAGS="-O2 -march=i486 -mcpu=i686"
+elif [ "$ARCH" = "s390" ]; then
+ SLKCFLAGS="-O2"
+elif [ "$ARCH" = "x86_64" ]; then
+ SLKCFLAGS="-O2"
+fi
+
+PKG=$TMP/package-$PRGNAM
+
+if [ ! -d $TMP/tmp-$PRGNAM ]; then
+ mkdir -p $TMP/tmp-$PRGNAM # location to build the source
+fi
+if [ ! -d $PKG ]; then
+ mkdir -p $PKG # place for the package to be built
+fi
+
+
+# --- PACKAGE BUILDING ---
+
+echo "++"
+echo "|| $PRGNAM-$VERSION"
+echo "++"
+
+rm -rf $PKG/*
+
+cd $PKG
+
+# Explode the package framework:
+if [ -f $CWD/_$PRGNAM.tar.gz ]; then
+ explodepkg $CWD/_$PRGNAM.tar.gz
+fi
+
+cd $TMP/tmp-$PRGNAM
+
+
+# --- TARBALL EXTRACTION,PATCH,MODIFY ---
+
+echo "Extracting the program tarball for $PRGNAM..."
+tar -xzvf $CWD/${PRGNAM}-${VERSION}.tgz
+
+cd ${PRGNAM}-${VERSION}
+
+chown -R root.root *
+
+
+# --- BUILDING ---
+
+echo Building ...
+
+mkdir -p $PKG/usr/bin $PKG/usr/lib $PKG/usr/man
+
+make 2>&1 | tee $CWD/make-${PRGNAM}.log
+
+cd qemu
+make
+cp vdeq $PKG/usr/bin
+(cd $PKG/usr/bin && ln -sf vdeq vdeqemu)
+cd ..
+
+#
+# Install all the needed stuff to the package dir
+#
+# Use installwatch if available:
+which installwatch > /dev/null 2>&1
+if [ $? == 0 ]; then
+ installwatch -o $CWD/install-${PRGNAM}.log \
+ make BIN_DIR=$PKG/usr/bin LIB_DIR=$PKG/usr/lib MAN_DIR=$PKG/usr/man install
+else
+ make BIN_DIR=$PKG/usr/bin LIB_DIR=$PKG/usr/lib MAN_DIR=$PKG/usr/man install \
+ 2>&1 |tee $CWD/install-${PRGNAM}.log
+fi
+
+# Fix incorrect link
+(cd $PKG/usr/bin &&
+ rm -f vdeqemu; ln -s vdeq vdeqemu
+)
+
+
+# --- DOCUMENTATION ---
+
+cp uml/README README.uml
+
+DOCS="COPYING LICENSE README README.uml VERSION $CWD/rc.vdenetwork"
+
+mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION
+cp -a $DOCS \
+ $PKG/usr/doc/$PRGNAM-$VERSION
+chmod -R -w $PKG/usr/doc/$PRGNAM-$VERSION/*
+
+# Compress the man page(s)
+gzip -9f $PKG/usr/man/*/*
+
+# Strip binaries
+( cd $PKG
+ find . | xargs file | grep "executable" | grep ELF | cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null
+ find . | xargs file | grep "shared object" | grep ELF | cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null
+)
+
+
+# --- OWNERSHIP, RIGHTS ---
+
+chmod -R o-w $PKG
+chgrp root:bin $PKG/usr/bin/* $PKG/usr/sbin/* \
+ $PKG/bin/* $PKG/sbin/* 2>/dev/null
+
+
+# --- PACKAGE DESCRIPTION ---
+
+mkdir -p $PKG/install
+cat $CWD/slack-desc > $PKG/install/slack-desc
+if [ -f $CWD/doinst.sh ]; then
+ cat $CWD/doinst.sh > $PKG/install/doinst.sh
+fi
+
+
+# --- BUILDING ---
+
+# Build the package:
+cd $PKG
+makepkg --linkadd y --chown n $TMP/$PRGNAM-$VERSION-$ARCH-$BUILD.tgz \
+ 2>&1 | tee $CWD/makepkg-${PRGNAM}.log
+(cd $TMP && md5sum $PRGNAM-$VERSION-$ARCH-$BUILD.tgz > $PRGNAM-$VERSION-$ARCH-$BUILD.tgz.md5)
+cat $CWD/slack-desc | grep "^${PRGNAM}" > $TMP/$PRGNAM-$VERSION-$ARCH-$BUILD.txt
+
+
+# --- CLEANUP ---
+
+# Clean up the extra stuff:
+if [ "$1" = "--cleanup" ]; then
+ rm -rf $TMP/tmp-$PRGNAM
+ rm -rf $PKG
+fi