aboutsummaryrefslogtreecommitdiff
path: root/sys/anacron/anacron.SlackBuild
diff options
context:
space:
mode:
Diffstat (limited to 'sys/anacron/anacron.SlackBuild')
-rw-r--r--sys/anacron/anacron.SlackBuild128
1 files changed, 128 insertions, 0 deletions
diff --git a/sys/anacron/anacron.SlackBuild b/sys/anacron/anacron.SlackBuild
new file mode 100644
index 00000000..ce90c9df
--- /dev/null
+++ b/sys/anacron/anacron.SlackBuild
@@ -0,0 +1,128 @@
+#!/bin/bash
+#
+# slackbuild script for anacron
+# by rhatto at riseup.net
+#
+
+if [ -s "slack-required" ]; then
+ echo Recomended and required packages for building anacron are:
+ cat slack-required | sed -e 's/^/\t/'
+ if [ "$INTERACT" != "no" ]; then
+ echo If you dont have those installed, press Ctrl-C. Otherwise, hit ENTER.
+ read crap
+# else
+# echo Sleeping 3 seconds...
+# sleep 3
+ fi
+fi
+
+CWD="`pwd`"
+
+if [ -f ~/.slackbuildrc ]; then
+ source ~/.slackbuildrc
+elif [ -f /etc/slackbuildrc ]; then
+ source /etc/slackbuildrc
+fi
+
+# default settings
+PACKAGE="anacron"
+ARCH=${ARCH:=i486}
+VERSION=${VERSION:=2.3}
+BUILD=${BUILD:=1rha}
+SRC_DIR=${SRC:=$CWD}
+TMP=${TMP:=/tmp}
+REPOS=${REPOS:=$TMP}
+
+if [ "$ARCH" == "x86_64" ]; then
+ export LDFLAGS="-L/lib64 -L/usr/lib64"
+ LIBDIR=/usr/lib64
+else
+ LIBDIR=/usr/lib
+fi
+
+# ------- error codes for createpkg --------------
+ERROR_WGET=31; ERROR_MAKE=32; ERROR_INSTALL=33
+ERROR_MD5=34; ERROR_CONF=35; ERROR_HELP=36
+ERROR_TAR=37; ERROR_MKPKG=38; ERROR_GPG=39
+ERROR_PATCH=40
+
+RTOOL="wget"
+PACKAGE_EXT="gz"
+SRC="$PACKAGE-$VERSION.tar.$PACKAGE_EXT"
+URL="http://easynews.dl.sourceforge.net/sourceforge/anacron/$SRC"
+
+SRC_DIR="$SRC_DIR/$PACKAGE"
+mkdir -p $SRC_DIR
+
+if [ "$RTOOL" == "wget" ] && [ ! -f "$SRC_DIR/$SRC" ]; then
+ wget "$URL" -O "$SRC_DIR/$SRC" || exit $ERROR_WGET
+fi
+
+TMP="$TMP/$PACKAGE"
+rm -rf $TMP
+mkdir -p $TMP
+cd $TMP
+
+tar xvf $SRC_DIR/$SRC || exit $ERROR_TAR
+cd $PACKAGE-$VERSION
+
+if [ -f "$CWD/$PACKAGE-$VERSION.diff" ]; then
+ patch -p1 < $CWD/$PACKAGE-$VERSION.diff || exit $ERROR_PATCH
+fi
+
+make || exit $ERROR_MAKE
+
+CWD="`pwd`"
+
+mkdir $TMP/package-$PACKAGE
+cd $TMP/package-$PACKAGE
+
+mkdir -p usr/sbin var/spool/anacron usr/man/man5 usr/man/man8
+cp $CWD/anacron usr/sbin
+cp $CWD/anacrontab.5 usr/man/man5
+cp $CWD/anacron.8 usr/man/man8
+
+gzip usr/man/man5/anacrontab.5
+gzip usr/man/man8/anacron.8
+
+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
+
+mkdir install
+cat << EOF > install/slack-desc
+# HOW TO EDIT THIS FILE:
+# The "handy ruler" below makes it easier to edit a package description. Line
+# up the first '|' above the ':' following the base package name, and the '|'
+# on the right side marks the last column you can put a character in. You must
+# make exactly 11 lines for the formatting to be correct. It's also
+# customary to leave one space after the ':'.
+
+ |-----handy-ruler-----------------------------------------------------|
+anacron: anacron (periodic command scheduler)
+anacron:
+anacron: Anacron is a periodic command scheduler. It executes commands at
+anacron: intervals specified in days. Unlike cron, it does not assume that the
+anacron: system is running continuously. It can therefore be used to control
+anacron: the execution of daily, weekly, and monthly jobs (or anything with
+anacron: a period of n days), on systems that don't run 24 hours a day. When
+anacron: installed and configured properly, Anacron will make sure that the
+anacron: commands are run at the specified intervals as closely as
+anacron: machine-uptime permits.
+anacron:
+EOF
+
+# docs
+mkdir -p usr/doc/$PACKAGE-$VERSION
+
+DOCS="COPYING ChangeLog README TODO"
+
+for file in $DOCS; do
+ cp $CWD/$file* usr/doc/$PACKAGE-$VERSION/
+done
+
+makepkg -c y -l y $REPOS/$PACKAGE-$VERSION-$ARCH-$BUILD.tgz || exit $ERROR_MKPKG
+
+if [ "$CLEANUP" == "yes" ]; then
+ rm -rf $TMP
+fi
+