aboutsummaryrefslogtreecommitdiff
path: root/sys/apps/openrc
diff options
context:
space:
mode:
Diffstat (limited to 'sys/apps/openrc')
-rw-r--r--sys/apps/openrc/Manifest24
-rw-r--r--sys/apps/openrc/openrc-0.5.0.diff27
-rw-r--r--sys/apps/openrc/openrc.SlackBuild257
3 files changed, 308 insertions, 0 deletions
diff --git a/sys/apps/openrc/Manifest b/sys/apps/openrc/Manifest
new file mode 100644
index 00000000..b82adf1e
--- /dev/null
+++ b/sys/apps/openrc/Manifest
@@ -0,0 +1,24 @@
+-----BEGIN PGP SIGNED MESSAGE-----
+Hash: SHA256
+
+DIST openrc-0.5.0.tar.bz2 150907 MD5 9ec7f8425e12abbbd0f7a962aae3fa3c RMD160 149b793aeecb174005da1d9e43f997dbdc63c5bd SHA1 2142d0e9d3db5941bf58d411b7d996532a333139 SHA256 168a19c38572e8f822137676eeae6233b507c8b8efcf19421cdc8675fc22e4c1 SHA512 dabecf7d644dac6e9f527699af308e2d099a5c96e0dc55406cac1b9054a0bd2c6ad99b23779cb775efb3f1c085a9878726596f8f360ebcaab3b66dab52489e28
+MKBUILD openrc.mkbuild 5192 MD5 e77be64c425fdd3dc9587bb97b4701a3 RMD160 b4d2665f02c71542429b497599f69f48183c0262 SHA1 f3f3fe115fc95f43d13f4740f101d06737382ad4 SHA256 5e6526459c9082012a1a233663b0a08c0262b90fc06124db84c184419b4f1deb SHA512 42ed5d879a49b7f945688bda010c25dad160c610fcf153325020f69f8aca208ff7b134af4765c1e5840875d6d4d7b1917cfc3b009067ab5d86e54a46090b84bc
+PATCH openrc-0.5.0.diff 1526 MD5 195fb9dc90e5ffc046c98f4ab6cffbcf RMD160 0a3840da6d69036d21421003da4220d84bdf73d3 SHA1 1ce4b0d60659e9d6f01cc576fde029be6c9d9e48 SHA256 91733ce86baed0621b571ecfbc3435009fee3d907373ae77c9377febd37f73d8 SHA512 7c5b8dae16af9693f8c1a59ad9c712272704d8745211f0aadf0860465aae12f3bcf1d6b96de91a5f0e055b4148acd01425d8f2a3f95da4fb812bdef094cfa6e9
+SLACKBUILD openrc.SlackBuild 8338 MD5 f716c68534885049c9e1a531971ce4c7 RMD160 87e0610db4f909b255a6d4c0e041932858f01558 SHA1 7da15a3a83e30a8626c95fbdb958f39ed6f50d2d SHA256 8652f9a177733f3fed23e61d07add6851866fc22b2c67dc5a33cf017b0921781 SHA512 01cedae92d83f93d8464c026a8e64474914fe4ea056899d55e7d5318abfa766d7b5003fafc2cf33ff0577be2b83aa7437786c0a4c61c51a1408901c022ab9721
+-----BEGIN PGP SIGNATURE-----
+Version: GnuPG v1.4.9 (GNU/Linux)
+
+iQIcBAEBCAAGBQJKR/tSAAoJEEHL93ESzgeiQg4QAI02v2wf1zJwwAt+sDD4B4kg
+/tx4uC6ZF3aDJXcSQHQI6NgZ5l8KvE5AyrFWcIaCEy6f0xaNQ+iop6O3FYwFtDXY
+Ikqmkf0r9QzKsDWRdW5GObsGBEfrVc6YcvFaiixohJmMlbqZnlyDOgNixhm9+m1W
+Jqf3VwnJVtoPQD5xsVFErmrRxfE0aVXkOaQqESCMkNhCodrek0mgyj8ahE5TNuXn
+Db2hC2BPC7bkteoFjKWFOd466gGILnefyj0TS5V9pQ6r7Aod7Yuds+6u9CWQ2Myz
+vS9f/k+iSYPDIytWOXjriuwaGMT3FZzMppNdiBQoii3Ce/itFi9YDcWFJcxLJ0bx
+l70amOs5KtwRP4m0K/soCyQ43SbKTMRurngbPXtQpHTF0jiGbQfXFAXCZn1NujMP
+8mvMRlWQzO4YowJDqH/T4Uif9hQ4z/QyC5EPrTCMexe2rWmBeHin3cAZlnDlGOLh
+Ob8zwmpXioY3IbpdrcByig8T1JCw9Y4zMz80PpbGM7C/1dWtthV0u1dQqXMZjeBf
+Qt3hqqWEKHoMtx9cRFEdP63Ky2iaPtqu2u6ukNJYrpmeS5u23M6kOi98Gtt6ccMg
+1IZWsampLbFDEL5qhgFsSkiv8TOfzHFW3fWZ8uhNFM2/085m08YnpCCePRdaSV/Z
+9rL5qWVuI/TRk0OXdI0A
+=Fq61
+-----END PGP SIGNATURE-----
diff --git a/sys/apps/openrc/openrc-0.5.0.diff b/sys/apps/openrc/openrc-0.5.0.diff
new file mode 100644
index 00000000..167c671c
--- /dev/null
+++ b/sys/apps/openrc/openrc-0.5.0.diff
@@ -0,0 +1,27 @@
+diff -Naur openrc-0.5.0.orig/LICENSE openrc-0.5.0/LICENSE
+--- openrc-0.5.0.orig/LICENSE 1969-12-31 21:00:00.000000000 -0300
++++ openrc-0.5.0/LICENSE 2009-06-28 20:11:00.000000000 -0300
+@@ -0,0 +1,23 @@
++Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
++All rights reserved
++
++Redistribution and use in source and binary forms, with or without
++modification, are permitted provided that the following conditions
++are met:
++1. Redistributions of source code must retain the above copyright
++ notice, this list of conditions and the following disclaimer.
++2. Redistributions in binary form must reproduce the above copyright
++ notice, this list of conditions and the following disclaimer in the
++ documentation and/or other materials provided with the distribution.
++
++THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``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 OR 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.
diff --git a/sys/apps/openrc/openrc.SlackBuild b/sys/apps/openrc/openrc.SlackBuild
new file mode 100644
index 00000000..40f5222d
--- /dev/null
+++ b/sys/apps/openrc/openrc.SlackBuild
@@ -0,0 +1,257 @@
+#!/bin/bash
+#
+# openrc.SlackBuild is free software; you can redistribute
+# it and/or modify it under the terms of the GNU General Public License as
+# published by the Free Software Foundation; either version 2 of the License,
+# or any later version.
+#
+# openrc.SlackBuild is distributed in the hope that it will
+# be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
+# Public License for more details.
+#
+# You should have received a copy of the GNU General Public License along
+# with this program; if not, write to the Free Software Foundation, Inc.,
+# 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
+#
+# slackbuild for openrc, by Silvio Rhatto
+# requires:
+# tested: openrc-0.5.0
+# model: generic.mkSlackBuild $Rev: 805 $
+#
+
+# Look for slackbuildrc
+if [ -f ~/.slackbuildrc ]; then
+ source ~/.slackbuildrc
+elif [ -f /etc/slackbuildrc ]; then
+ source /etc/slackbuildrc
+fi
+
+# Set variables
+CWD="$(pwd)"
+SRC_NAME="openrc"
+PKG_NAME="openrc"
+ARCH=${ARCH:=i486}
+SRC_VERSION=${VERSION:=0.5.0}
+PKG_VERSION="$(echo "$SRC_VERSION" | tr '[[:blank:]-]' '_')"
+BUILD=${BUILD:=1rha}
+SRC_DIR=${SRC_DIR:=$CWD}/$PKG_NAME
+TMP=${TMP:=/tmp}
+PKG=${PKG:=$TMP/package-$PKG_NAME}
+REPOS=${REPOS:=$TMP}
+SLACKBUILD_PATH=${SLACKBUILD_PATH:="sys/apps/openrc"}
+PREFIX=${PREFIX:=/usr}
+PKG_WORK="$TMP/$SRC_NAME"
+CONF_OPTIONS=${CONF_OPTIONS:=""}
+NUMJOBS=${NUMJOBS:=""}
+
+# Set system libraries' path and optmization flags based on $ARCH
+LIBDIR="$PREFIX/lib"
+
+if [ "$ARCH" = "i386" ]; then
+ SLKCFLAGS="-O2 -march=i386 -mtune=i686"
+elif [ "$ARCH" = "i486" ]; then
+ SLKCFLAGS="-O2 -march=i486 -mtune=i686"
+elif [ "$ARCH" = "i686" ]; then
+ SLKCFLAGS="-O2 -march=i686"
+elif [ "$ARCH" = "s390" ]; then
+ SLKCFLAGS="-O2"
+elif [ "$ARCH" = "x86_64" ]; then
+ SLKCFLAGS="-O2 -fPIC"
+ LIBDIR="$PREFIX/lib64"
+ LDFLAGS="-L/lib64 -L/usr/lib64"
+fi
+
+# Set error codes (used by 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; ERROR_VCS=41; ERROR_MKDIR=42
+ERROR_MANIFEST=43;
+
+# Clean up any leftovers of previous builds
+rm -rf "$PKG_WORK" 2> /dev/null
+rm -rf "$PKG" 2> /dev/null
+
+# Create directories if necessary
+mkdir -p "$SRC_DIR" || exit $ERROR_MKDIR
+mkdir -p "$PKG" || exit $ERROR_MKDIR
+mkdir -p "$REPOS" || exit $ERROR_MKDIR
+mkdir -p "$PKG_WORK" || exit $ERROR_MKDIR
+
+# Dowload source if necessary
+SRC="$SRC_NAME-$VERSION.tar.bz2"
+URL="http://roy.marples.name/downloads/openrc/$SRC"
+
+if [ ! -s "$SRC_DIR/$SRC" ] || ! bunzip2 -t "$SRC_DIR/$SRC" 2> /dev/null; then
+ wget "$URL" -O "$SRC_DIR/$SRC" || exit $ERROR_WGET
+fi
+
+# Check Manifest file
+if [ -e "$CWD/Manifest" ]; then
+
+ # Manifest signature checking
+ if grep -q -- "-----BEGIN PGP SIGNED MESSAGE-----" $CWD/Manifest; then
+ echo "Checking Manifest signature..."
+ gpg --verify $CWD/Manifest
+ if [ "$?" != "0" ]; then
+ exit $ERROR_MANIFEST
+ fi
+ fi
+
+ MANIFEST_LINES="`grep -E -v "^(MKBUILD|SLACKBUILD)" $CWD/Manifest | wc -l`"
+
+ for ((MANIFEST_COUNT=1; MANIFEST_COUNT <= $MANIFEST_LINES; MANIFEST_COUNT++)); do
+
+ MANIFEST_LINE="`grep -E -v "^(MKBUILD|SLACKBUILD)" $CWD/Manifest | head -n $MANIFEST_COUNT | tail -n 1`"
+ MANIFEST_FILE="`echo $MANIFEST_LINE | awk '{ print $2 }'`"
+ MANIFEST_FILE_TYPE="`echo $MANIFEST_LINE | awk '{ print $1 }'`"
+
+ if [ -e "$SRC_DIR/$MANIFEST_FILE" ]; then
+ MANIFEST_FILE="$SRC_DIR/$MANIFEST_FILE"
+ else
+ MANIFEST_FILE="`find $CWD -name $MANIFEST_FILE`"
+ fi
+
+ if [ ! -e "$MANIFEST_FILE" ] || [ -d "$MANIFEST_FILE" ]; then
+ continue
+ fi
+
+ echo "Checking Manifest for $MANIFEST_FILE_TYPE $MANIFEST_FILE integrity..."
+
+ SIZE_SRC="`wc -c $MANIFEST_FILE | awk '{ print $1 }'`"
+ SIZE_MANIFEST="`echo $MANIFEST_LINE | awk '{ print $3 }'`"
+
+ # Check source code size
+ if [ "$SIZE_SRC" != "$SIZE_MANIFEST" ]; then
+ echo "SIZE Manifest: $SIZE_MANIFEST; SIZE $SRC: $SIZE_SRC"
+ exit $ERROR_MANIFEST
+ else
+ echo "Size match."
+ fi
+
+ # Check source code integrity
+ for ALGO in md5 rmd160 sha1 sha256 sha512; do
+ if [ $ALGO = "rmd160" ]; then
+ ALGO_SRC="`openssl rmd160 $MANIFEST_FILE | awk '{ print $2 }'`"
+ else
+ ALGO_SRC="`"$ALGO"sum $MANIFEST_FILE | awk '{ print $1 }'`"
+ fi
+ ALGO="`echo $ALGO | tr '[:lower:]' '[:upper:]'`"
+ ALGO_MANIFEST=$(echo $MANIFEST_LINE | sed "s/.* $ALGO //" | awk '{ print $1 }')
+ if [ "$ALGO_SRC" != "$ALGO_MANIFEST" ]; then
+ echo "$ALGO Manifest: $ALGO_MANIFEST; $ALGO $SRC: $ALGO_SRC"
+ exit $ERROR_MANIFEST
+ else
+ echo "$ALGO match."
+ fi
+ done
+
+ done
+
+else
+ exit $ERROR_MANIFEST
+fi
+
+# Untar
+cd "$PKG_WORK"
+tar --no-same-owner --no-same-permissions -xvf "$SRC_DIR/$SRC" || exit $ERROR_TAR
+PKG_SRC="$PWD/`ls -l | awk '/^d/ { print $NF }'`"
+cd "$PKG_SRC"
+
+# Patch source
+patches=" [[PATCH URLS]]
+ $PKG_NAME.diff $PKG_NAME-$PKG_VERSION.diff
+ $PKG_NAME-$PKG_VERSION-$ARCH.diff $PKG_NAME-$ARCH.diff"
+for patch in $patches; do
+ patch="`basename $patch`"
+ if [ -f "$CWD/$patch" ]; then
+ patch -Np1 < "$CWD/$patch" || exit $ERROR_PATCH
+ elif [ -f "$CWD/patches/$patch" ]; then
+ patch -Np1 < "$CWD/patches/$patch" || exit $ERROR_PATCH
+ elif [ -f "$CWD/$patch.gz" ]; then
+ gzip -dc "$CWD/$patch.gz" | patch -Np1 || exit $ERROR_PATCH
+ elif [ -f "$CWD/patches/$patch.gz" ]; then
+ gzip -dc "$CWD/patches/$patch.gz" | patch -Np1 || exit $ERROR_PATCH
+ elif [ -f "$SRC_DIR/$patch" ]; then
+ if [ "`basename $patch .gz`" != "$patch" ]; then
+ gzip -dc $SRC_DIR/$patch | patch -Np1 || exit $ERROR_PATCH
+ elif [ "`basename $patch .bz2`" != "$patch" ]; then
+ bzip2 -dc $SRC_DIR/$patch | patch -Np1 || exit $ERROR_PATCH
+ else
+ patch -Np1 < "$SRC_DIR/$patch" || exit $ERROR_PATCH
+ fi
+ fi
+done
+
+# Compile
+make $NUMJOBS || exit $ERROR_MAKE
+
+# Install
+make install DESTDIR="$PKG" || exit $ERROR_INSTALL
+
+# 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
+)
+
+# Compress and link manpages
+if [ -d "$PKG/$PREFIX/man" ]; then
+ ( cd "$PKG/$PREFIX/man"
+ for manpagedir in $(find . -type d -name "man*") ; do
+ ( cd $manpagedir
+ for eachpage in $( find . -type l -maxdepth 1) ; do
+ ln -s $( readlink $eachpage ).gz $eachpage.gz
+ rm $eachpage
+ done
+ gzip -9 *.?
+ )
+ done
+ )
+fi
+
+# Install documentation
+DOCS="README TODO"
+mkdir -p "$PKG/usr/doc/$PKG_NAME-$PKG_VERSION" || exit $ERROR_MKDIR
+for doc in $DOCS; do
+ if [ -f "$doc" ]; then
+ cp -a $doc "$PKG/usr/doc/$PKG_NAME-$PKG_VERSION"
+ fi
+done
+
+# Add package description (slack-desc)
+mkdir -p "$PKG/install" || exit $ERROR_MKDIR
+cat << EODESC > "$PKG/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-------------------------------------------------------|
+openrc: openrc
+openrc:
+openrc: OpenRC is a dependency based init system that works with
+openrc: the system provided init program, normally /sbin/init.
+openrc: It is not a replacement for /sbin/init. OpenRC is 100%
+openrc: compatible with Gentoo init scripts, which means you
+openrc: can probably find one for the daemons you want to start
+openrc: in the Gentoo Portage Tree. OpenRC also provides an init
+openrc: script that runs BSD rc.d style scripts too, making it
+openrc: easy to port your BSD system to OpenRC.
+openrc:
+EODESC
+
+# Build the package
+cd "$PKG"
+mkdir -p $REPOS/$SLACKBUILD_PATH
+makepkg -l y -c n "$REPOS/$SLACKBUILD_PATH/$PKG_NAME-$PKG_VERSION-$ARCH-$BUILD.tgz" || exit $ERROR_MKPKG
+
+# Delete source and build directories if requested
+if [ "$CLEANUP" == "yes" ] || [ "$1" = "--cleanup" ]; then
+ rm -rf "$PKG_WORK" "$PKG"
+fi