#!/bin/bash

# cryptsetup.SlackBuild
# Heavily based on the original Slackware build scripts,
# Modified by Stuart Winter <stuart@armedslack.org>

# Record toolchain & other info for the build log:
slackbuildinfo

# Paths to skeleton port's source & real Slackware source tree:
export CWD=$SLACKSOURCE/$PKGSERIES/$PKGNAM
export PORTCWD=$PWD

# Temporary build locations:
export TMPBUILD=$TMP/build-$PKGNAM
export PKG=$TMP/package-$PKGNAM
mkpkgdirs # Delete & re-create temporary directories then cd into $TMPBUILD

# Determine the CFLAGS for the known architectures:
case $PORTARCH in
   arm)     export SLKCFLAGS="-O2 -march=armv3 -mtune=xscale" ;;
   powerpc) export SLKCFLAGS="-O2" ;;
   sparc)   export SLKCFLAGS="-O2" ;;
   hppa)    export SLKCFLAGS="-O2" ;;
   *)       export SLKCFLAGS="-O2" ;;
esac

# Extract source:
tar xvvf $CWD/$PKGNAM-$VERSION.tar.bz2
cd $PKGNAM-$VERSION
slackhousekeeping

# Configure:
LDFLAGS="$SLKLDFLAGS" \
CFLAGS="$SLKCFLAGS" \
./configure \
   --prefix=/usr \
   --libdir=/usr/lib${LIBDIRSUFFIX} \
   --localstatedir=/var \
   --sysconfdir=/etc \
   --datarootdir=/usr \
   --datadir=/usr/share \
   --localedir=/usr/share/locale \
   --enable-libgcrypt \
   --enable-libdevmapper \
   --program-prefix="" \
   --program-suffix="" \
   --build=$ARCH-slackware-linux || failconfig

# Build:
make $NUMJOBS || failmake

# Install into package framework:
make install DESTDIR=$PKG || failinstall

# Build static version that is used for mkinitrd:
make clean
echo Building ...
LDFLAGS="$SLKLDFLAGS" \
CFLAGS="$SLKCFLAGS" \
./configure \
   --prefix=/usr \
   --libdir=/usr/lib${LIBDIRSUFFIX} \
   --localstatedir=/var \
   --sysconfdir=/etc \
   --datarootdir=/usr \
   --datadir=/usr/share \
   --enable-libgcrypt \
   --enable-libdevmapper \
   --enable-static \
   --disable-shared \
   --disable-shared-library \
   --program-prefix="" \
   --program-suffix="" \
   --build=$ARCH-slackware-linux || failconfig

# Build:
make $NUMJOBS || failmake
mkdir -p $PKG/sbin

# Install into package:
install -vpm755 src/cryptsetup $PKG/sbin/cryptsetup.static

# Now that we have the .static version, it only makes sense to
# use it by default (even when calling /usr/sbin/cryptsetup).
# This avoids missing library issues if someone installs an
# encrypted system using only the A package series.
#
# This is small, so save it:
mv $PKG/usr/sbin/cryptsetup $PKG/usr/sbin/cryptsetup.dynamic
# Replace with a link:
( cd $PKG/usr/sbin ; ln -vsf ../../sbin/cryptsetup.static cryptsetup )
# Put one in /sbin too, in case someone tries to use /sbin/cryptsetup:
( cd $PKG/sbin ; ln -vsf cryptsetup.static cryptsetup )

# Copy docs:
DOCS='AUTHORS COPYING* ChangeLog INSTALL NEWS README TODO'
mkdir -p $PKG/usr/doc/$PKGNAM-$VERSION
cp -favv $DOCS $PKG/usr/doc/$PKGNAM-$VERSION/

# If necessary, start the fakeroot server so we can set file/dir ownerships:
start_fakeroot

# Apply generic Slackware packaging policies:
cd $PKG
slackstripall   # strip all .a archives and all ELFs
slackgzpages -i # compress man & info pages and delete usr/info/dir
slackslack      # chown -R root:root, chmod -R og-w, slackchown, slack644docs
slackdesc       # install slack-desc and doinst.sh
slackmp         # run makepkg -l y -c n

# Perform any final checks on the package:
cd $PKG
slackhlinks     # search for any hard links
