diff options
author | Eric Hameleers <alien@slackware.com> | 2007-07-26 20:35:28 +0000 |
---|---|---|
committer | Eric Hameleers <alien@slackware.com> | 2007-07-26 20:35:28 +0000 |
commit | 1d4508350fc3d18bed019c42af7648f4d693d8ff (patch) | |
tree | 789cf1a3fea1296755646358bd0cf2362feea55b | |
parent | 68425b06654ff8f70da896e736c355c7fa5395ef (diff) | |
download | asb-1d4508350fc3d18bed019c42af7648f4d693d8ff.tar.gz asb-1d4508350fc3d18bed019c42af7648f4d693d8ff.tar.xz |
Update
-rwxr-xr-x | ms-sys/build/ms-sys.SlackBuild | 197 |
1 files changed, 84 insertions, 113 deletions
diff --git a/ms-sys/build/ms-sys.SlackBuild b/ms-sys/build/ms-sys.SlackBuild index ee6e9a12..bef2b4a4 100755 --- a/ms-sys/build/ms-sys.SlackBuild +++ b/ms-sys/build/ms-sys.SlackBuild @@ -1,6 +1,25 @@ #!/bin/sh # $Id$ -# Copyright (c) 2006 Eric Hameleers <alien@slackware.com> +# Copyright (c) 2007 Eric Hameleers <alien@slackware.com> +# All rights reserved. +# +# Permission to use, copy, modify, and distribute this software for +# any purpose with or without fee is hereby granted, provided that +# the above copyright notice and this permission notice appear in all +# copies. +# +# THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED 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 AUTHORS AND COPYRIGHT HOLDERS AND THEIR +# CONTRIBUTORS 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. # ----------------------------------------------------------------------------- # # Slackware SlackBuild script @@ -13,47 +32,49 @@ # Changelog: # 2.1.1-1: 24/Sep/2006 by Eric Hameleers <alien@slackware.com> # * Initial build. +# 2.1.2-1: 26/Jul/2007 by Eric Hameleers <alien@slackware.com> +# * Update. # -# Run 'sh SlackBuild --cleanup' to build a Slackware package. +# Run 'sh ms-sys.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: PRGNAM=ms-sys -VERSION=${VERSION:-2.1.1} +VERSION=${VERSION:-2.1.2} ARCH=${ARCH:-i486} -BUILD=1 +BUILD=${BUILD:-1} + +DOCS="CHANGELOG CONTRIBUTORS COPYING README TODO" # Where do we look for sources? CWD=`pwd` SRCDIR=`dirname $0` [ "${SRCDIR:0:1}" == "." ] && SRCDIR=${CWD}/${SRCDIR} -# Place to build (TMP) and package (PKG) the program: -TMP=${TMP:-/tmp} +# Place to build (TMP) package (PKG) and output (OUTPUT) the program: +TMP=${TMP:-/tmp/build} PKG=$TMP/package-$PRGNAM +OUTPUT=${OUTPUT:-/tmp} + +# Input URL: http://dl.sourceforge.net/ms-sys/ms-sys-2.1.2.tgz +SOURCE="$SRCDIR/${PRGNAM}-${VERSION}.tgz" +SRCURL="http://dl.sourceforge.net/${PRGNAM}/${PRGNAM}-${VERSION}.tgz" + +## +## --- with a little luck, you won't have to edit below this point --- ## +## # Exit the script on errors: set -e +trap 'echo "$0 FAILED at line $LINENO!" | tee $OUTPUT/error-${PRGNAM}.log' ERR # Catch unitialized variables: set -u P1=${1:-1} - -# This covers most filenames you'd want as documentation. Change if needed. -DOCS="CHANGELOG CONTRIBUTORS COPYING README TODO" - -SOURCE="${PRGNAM}-${VERSION}.tgz" -SRCURL="http://dl.sourceforge.net/sourceforge/${PRGNAM}/${PRGNAM}-${VERSION}.tgz" - -## -## --- with a little luck, you won't have to edit below this point --- ## -## - # Slackware 11 and up need other option (gcc > 3.3.x) if [ `gcc -dumpversion | tr -d '.' |cut -c 1-2` -gt 33 ]; then MOPT=tune @@ -82,29 +103,28 @@ case "$ARCH" in ;; esac -if [ ! -d $TMP/tmp-$PRGNAM ]; then - mkdir -p $TMP/tmp-$PRGNAM # location to build the source -elif [ "$P1" != "--oldbuild" ]; then - # If the "--oldbuild" parameter is present, we keep - # the old build files and continue; - # By default we remove the remnants of previous build and continue: - rm -rf $TMP/tmp-$PRGNAM/* -fi +# Create working directories: +mkdir -p $TMP/tmp-$PRGNAM # location to build the source +rm -rf $TMP/tmp-$PRGNAM/* # By default we remove the remnants of previous build +mkdir -p $PKG # place for the package to be built +rm -rf $PKG/* # We always erase old package's contents: +mkdir -p $OUTPUT # place for the package to be saved - -# --- SOURCE FILE AVAILABILITY --- - -if ! [ -f ${SRCDIR}/${SOURCE} ]; then +# Source file availability: +if ! [ -f ${SOURCE} ]; then if ! [ "x${SRCURL}" == "x" ]; then - echo "Source '${SOURCE}' not available yet... will download now:" - wget -nv -O "${SRCDIR}/${SOURCE}" "${SRCURL}" || true - if [ $? -ne 0 ]; then - echo "Downloading '${SOURCE}' failed... aborting the build." - mv -f "${SRCDIR}/${SOURCE}" "${SRCDIR}/${SOURCE}".FAIL + # Check if the $SRCDIR is writable at all - if not, download to $OUTPUT + [ -w "$SRCDIR" ] || SOURCE="$OUTPUT/`basename $SOURCE`" + echo "Source '`basename ${SOURCE}`' not available yet..." + echo "Will download file to `dirname $SOURCE`" + wget -nv --connect-timeout=30 -O "${SOURCE}" "${SRCURL}" || true + if [ $? -ne 0 -o ! -s "${SOURCE}" ]; then + echo "Downloading '`basename ${SOURCE}`' failed... aborting the build." + mv -f "${SOURCE}" "${SOURCE}".FAIL exit 1 fi else - echo "File '${SOURCE}' not available... aborting the build." + echo "File '`basename ${SOURCE}`' not available... aborting the build." exit 1 fi fi @@ -120,108 +140,59 @@ echo "++" echo "|| $PRGNAM-$VERSION" echo "++" -if [ ! -d $PKG ]; then - mkdir -p $PKG # place for the package to be built -else - rm -rf $PKG/* # We always erase old package's contents: -fi - -cd $PKG - -# Explode the package framework: -if [ -f $SRCDIR/_$PRGNAM.tar.gz ]; then - explodepkg $SRCDIR/_$PRGNAM.tar.gz -fi - cd $TMP/tmp-$PRGNAM - - -# --- TARBALL EXTRACTION,PATCH,MODIFY --- - echo "Extracting the source archive(s) for $PRGNAM..." -if `file $SRCDIR/${SOURCE} | grep -q ": bzip2"`; then - tar -xjvf $SRCDIR/${SOURCE} || true -elif `file $SRCDIR/${SOURCE} | grep -qi ": zip"`; then - unzip $SRCDIR/${SOURCE} || true -elif `file $SRCDIR/${SOURCE} | grep -qi ": 7-zip"`; then - 7za -x $SRCDIR/${SOURCE} || true -else - tar -xzvf $SRCDIR/${SOURCE} || true -fi -if [ $? -ne 0 ]; then - echo "Error in unpacking '${SOURCE}!' Aborting..." - exit $? +if `file ${SOURCE} | grep -q ": bzip2"`; then + tar -xjvf ${SOURCE} +elif `file ${SOURCE} | grep -q ": gzip"`; then + tar -xzvf ${SOURCE} fi cd ${PRGNAM}-${VERSION} - -chown -R root.root * -find . -perm 777 -exec chmod 755 {} \; -find . -perm 666 -exec chmod 644 {} \; - - -# --- BUILDING --- +chown -R root:root . +chmod -R u+w,go+r-w,a-s . echo Building ... - LDFLAGS="$SLKLDFLAGS" \ CFLAGS="$SLKCFLAGS" \ -make PREFIX=/usr 2>&1 | tee $CWD/make-${PRGNAM}.log +make PREFIX=/usr 2>&1 | tee $OUTPUT/make-${PRGNAM}.log -# # Install all the needed stuff to the package dir -# -mkdir -p $PKG/usr/{bin,man,share} -# Use installwatch if available: +# Use installwatch if available, to produce a logfile of the installation +# process that is more easily readable: if `which installwatch > /dev/null 2>&1`; then - installwatch -o $CWD/install-${PRGNAM}.log make PREFIX=$PKG/usr install + installwatch -o $OUTPUT/install-${PRGNAM}.log make PREFIX=$PKG/usr install else - make PREFIX=$PKG/usr install 2>&1 |tee $CWD/install-${PRGNAM}.log + make PREFIX=$PKG/usr install 2>&1 |tee $OUTPUT/install-${PRGNAM}.log fi - -# --- DOCUMENTATION --- - +# Add documentation: mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION -cp -a $DOCS \ - $PKG/usr/doc/$PRGNAM-$VERSION +cp -a $DOCS $PKG/usr/doc/$PRGNAM-$VERSION || true chmod -R a-w $PKG/usr/doc/$PRGNAM-$VERSION/* -# Compress the man page(s) -[ -d $PKG/usr/man ] && \ +# Compress the man page(s): +if [ -d $PKG/usr/man ]; then find $PKG/usr/man -type f -name "*.?" -exec gzip -9f {} \; + for i in `find $PKG/usr/man -type l -name "*.?"` ; do ln -s $( readlink $i ).gz $i.gz ; rm $i ; done +fi -# 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 - - -# --- PACKAGE DESCRIPTION --- +# Strip binaries: +cd $PKG +find . | xargs file | grep "executable" | grep ELF | cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null || true +find . | xargs file | grep "shared object" | grep ELF | cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null || true +cd - +# Add a package description: mkdir -p $PKG/install cat $SRCDIR/slack-desc > $PKG/install/slack-desc -if [ -f $SRCDIR/doinst.sh ]; then - cat $SRCDIR/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 $PKG/install/slack-desc | grep "^${PRGNAM}" > $TMP/${PRGNAM}-${VERSION}-${ARCH}-${BUILD}.txt - - -# --- CLEANUP --- +makepkg --linkadd y --chown n $OUTPUT/${PRGNAM}-${VERSION}-${ARCH}-${BUILD}.tgz 2>&1 | tee $OUTPUT/makepkg-${PRGNAM}.log +cd $OUTPUT +md5sum ${PRGNAM}-${VERSION}-${ARCH}-${BUILD}.tgz > ${PRGNAM}-${VERSION}-${ARCH}-${BUILD}.tgz.md5 +cd - +cat $PKG/install/slack-desc | grep "^${PRGNAM}" > $OUTPUT/${PRGNAM}-${VERSION}-${ARCH}-${BUILD}.txt # Clean up the extra stuff: if [ "$P1" = "--cleanup" ]; then |