]> gitweb.fluxo.info Git - slackbuilds.git/commitdiff
amule: adding amule and dependency; apg: adding apg; cryptlib: adding cryptlib
authorrhatto <rhatto@370017ae-e619-0410-ac65-c121f96126d4>
Wed, 24 Jun 2009 04:43:30 +0000 (04:43 +0000)
committerrhatto <rhatto@370017ae-e619-0410-ac65-c121f96126d4>
Wed, 24 Jun 2009 04:43:30 +0000 (04:43 +0000)
git-svn-id: svn+slack://slack.fluxo.info/var/svn/slackbuilds@2210 370017ae-e619-0410-ac65-c121f96126d4

12 files changed:
app/admin/apg/Manifest [new file with mode: 0644]
app/admin/apg/apg-2.2.3.diff [new file with mode: 0644]
app/admin/apg/apg-2.3.0b.diff [new file with mode: 0644]
app/admin/apg/apg.SlackBuild [new file with mode: 0644]
dev/libs/cryptlib/Manifest [new file with mode: 0644]
dev/libs/cryptlib/cryptlib.SlackBuild [new file with mode: 0644]
dev/libs/crypto++/Manifest [new file with mode: 0644]
dev/libs/crypto++/crypto++-5.6.0.diff [new file with mode: 0644]
dev/libs/crypto++/crypto++.SlackBuild [new file with mode: 0644]
net/p2p/amule/Manifest [new file with mode: 0644]
net/p2p/amule/aMule.SlackBuild
net/p2p/amule/slack-required

diff --git a/app/admin/apg/Manifest b/app/admin/apg/Manifest
new file mode 100644 (file)
index 0000000..d29f342
--- /dev/null
@@ -0,0 +1,26 @@
+-----BEGIN PGP SIGNED MESSAGE-----
+Hash: SHA256
+
+DIST apg-2.2.3.tar.gz 108186 MD5 3b3fc4f11e90635519fe627c1137c9ac RMD160 ccc1d8a90fcac90717a9ee16fcc85de53d5ef90d SHA1 7bdbc931ef8477717186dc3ab3a2d3c25012b4ca SHA256 69c9facde63958ad0a7630055f34d753901733d55ee759d08845a4eda2ba7dba SHA512 d2479dc2cb5d571ddea23d98e9d4ddbdfff874013ff27c00073a3231c4c1d0ee9b75d3983331f3513755b57527766cc5a35e6829cdca15d2e9293dfbc4c2788a
+DIST apg-2.3.0b.tar.gz 109995 MD5 bd82400a5a731070ce895313576afe24 RMD160 18f9955d6fdb721bec26613860b312d7fea6fba7 SHA1 d729c939adb659c05fd0ea3d9c03842c6fe86fed SHA256 d1e52029709e2d7f9cb99bedce3e02ee7a63cff7b8e2b4c2bc55b3dc03c28b92 SHA512 3112d2267f2311f960a52fa268b55a5faf0250a4a8c5e7444f0c1326afa2844a476a54befcf79e5b8532d74c53f6f58ffc420591c8c36798dd82b43c14869e1a
+MKBUILD apg.mkbuild 4824 MD5 564531eca2616fc3ce22e656841cb6f4 RMD160 6b262bdfd330f01386869e3bf5ac27cd482ad3ea SHA1 2288a8d8d9b8613923c12c230edd29acd28d6940 SHA256 f9ace49664b82f1b3edecbf55c7fd4f5edeeb9d95106d70ae9257a1e172957d6 SHA512 cc47ef0cba123a170fd5e8bd8f3196abc08e631b750a3a3e112fb9a20bbe38deaac1b035dd61c981f6e25f18a34ae5d342b636dd6fb858fdf052458a13a40450
+PATCH apg-2.2.3.diff 2109 MD5 ec67d7c811f7368f206a426e7fb5954a RMD160 a859241058276d5ee49a293108ae98c7d6a5b6ac SHA1 de29b2140db74c4af2da403654be8946bce94034 SHA256 1b47bc6a08f697c34743fd96afd6b07b27494ecafbbd1473bc618839c82a9623 SHA512 876838282fa76d3675994c464851d11e8469fd92a23adc4c89715464f0e15507fa13e44084b7ac17d3228dc4213fe98d59b44e3f687a42b075f7a2f051c7cd84
+PATCH apg-2.3.0b.diff 2341 MD5 612185c62bfdd37f6fb6398f391709fa RMD160 573e62d92c4c119ebcf1865e4ad527a08c743bda SHA1 adfb47b79a2f774aea7445c1814dd87aa013457b SHA256 50efb4689d23f20e9e310ffd4168b9c896c67e9dca0c8b458b377e4705d382c5 SHA512 1b29a1b21a868724052877ca5d3e34f68c0a5ade01632463a3a801ac9412b70cb8c646a16271a1d5828e81f2cdf73aa4e8c5c7fe78cba73696bcdfd4a1aaa866
+SLACKBUILD apg.SlackBuild 7587 MD5 75cef7cda66e0752fb1982ee7ec5bedb RMD160 3db04f4c7d3ed92c1e258d8a0f8bfab6ae2a9bb9 SHA1 dff8dd37d68976f85f26925350f3bf6da2173679 SHA256 87023ee21367048509c43855cf80c70df855e3b128cacd70139edab3193a09b8 SHA512 3f90f11344eee02d2c975d059a0f392a394923ff26f1f74d3c359d51ec1b300773b0bf08c40627d1029d432ba5228711c9e21ac772bcf69a0f220d03a3d8b904
+-----BEGIN PGP SIGNATURE-----
+Version: GnuPG v1.4.9 (GNU/Linux)
+
+iQIcBAEBCAAGBQJKQZpsAAoJEEHL93ESzgeih/AQALL97pSx9LAMz6uOCYdlKKHK
+5Qt7XKxtCnQm96mXdLuzlo8GIhFrUHevCsB3peWh2jDJIkGkwXorVtr5Yk5t3Uv8
+v9uzC0afqjN5zDnB6gT7oO7kOz8Kiq5X79YpiymPdJ0uh86/uSBBaS6i6lE8c3pi
+UP01SEquTxUNAv1gSyroLbo/h+UBRf9zzNG+HLQ4QLDNY2Rhz3g37eAPhLXcM2N+
+H1THNs+mkrVq6jcKhIv/30s6GnpyMEp1GyZLOmge5EU3SqsbOs2RDgjuegJQk/Yp
+oqPnv0hi1K1GU+y13Q99Z+WGmJVIpugYbWYFLWjxWF5pkyosXJSQLGdHuzd+4PZI
+L5jnNMdNbVt7C/pjwWs5Pu33iUF5fOFI7VLYfmw2nodYskUmmf9hbDdJZtY1nVgZ
+ikoRCik04kyn57nf1p8b2OfD/+LcDAr8mHYj7wFNmOv13L00IydRcaSP7rm3vw/5
+l5hNmzD94wGo40Xwk+nFmqzuO0eVnepMA2YtQyD2E4U3EpFkfqdhU6F/Udanbavd
+hlOts/TXNqWHC00owQ7WfKWa4wW9UN3nDW0e5IW66DjXmD8BTN+pLZEjUjncZQqf
+ecr+z+MbY4f7zDeW9oaz1jLp6DqGNg8+QgN3vuzWqzjjI954yRl33lp3SvW8VLBJ
+1kOw6gm4OnvZ5VmzxWe7
+=QZTF
+-----END PGP SIGNATURE-----
diff --git a/app/admin/apg/apg-2.2.3.diff b/app/admin/apg/apg-2.2.3.diff
new file mode 100644 (file)
index 0000000..39bfc69
--- /dev/null
@@ -0,0 +1,38 @@
+diff -Naur apg-2.2.3.orig/Makefile apg-2.2.3/Makefile
+--- apg-2.2.3.orig/Makefile    2003-08-07 12:40:30.000000000 -0300
++++ apg-2.2.3/Makefile 2009-06-24 00:05:09.000000000 -0300
+@@ -111,22 +111,22 @@
+ install:
+       if test -x ./apg; then \
+-./mkinstalldirs ${INSTALL_PREFIX}${APG_BIN_DIR}; \
+-./mkinstalldirs ${INSTALL_PREFIX}${APG_MAN_DIR}; \
+-./install-sh -c -m 0755 -o root -g ${FIND_GROUP} ./apg ${INSTALL_PREFIX}${APG_BIN_DIR}; \
+-./install-sh -c -m 0444 ./doc/man/apg.1 ${INSTALL_PREFIX}${APG_MAN_DIR}; \
++./mkinstalldirs ${DESTDIR}/${INSTALL_PREFIX}${APG_BIN_DIR}; \
++./mkinstalldirs ${DESTDIR}/${INSTALL_PREFIX}${APG_MAN_DIR}; \
++./install-sh -c -m 0755 -o root -g ${FIND_GROUP} ./apg ${DESTDIR}/${INSTALL_PREFIX}${APG_BIN_DIR}; \
++./install-sh -c -m 0444 ./doc/man/apg.1 ${DESTDIR}/${INSTALL_PREFIX}${APG_MAN_DIR}; \
+ fi
+       if test -x ./apgd; then \
+-./mkinstalldirs ${INSTALL_PREFIX}${APGD_BIN_DIR}; \
+-./mkinstalldirs ${INSTALL_PREFIX}${APGD_MAN_DIR}; \
+-./install-sh -c -m 0755 -o root -g ${FIND_GROUP} ./apgd ${INSTALL_PREFIX}${APGD_BIN_DIR}; \
+-./install-sh -c -m 0444 ./doc/man/apgd.8 ${INSTALL_PREFIX}${APGD_MAN_DIR}; \
++./mkinstalldirs ${DESTDIR}/${INSTALL_PREFIX}${APGD_BIN_DIR}; \
++./mkinstalldirs ${DESTDIR}/${INSTALL_PREFIX}${APGD_MAN_DIR}; \
++./install-sh -c -m 0755 -o root -g ${FIND_GROUP} ./apgd ${DESTDIR}/${INSTALL_PREFIX}${APGD_BIN_DIR}; \
++./install-sh -c -m 0444 ./doc/man/apgd.8 ${DESTDIR}/${INSTALL_PREFIX}${APGD_MAN_DIR}; \
+ fi
+       if test -x ./apgbfm; then \
+-./mkinstalldirs ${INSTALL_PREFIX}${APG_BIN_DIR}; \
+-./mkinstalldirs ${INSTALL_PREFIX}${APG_MAN_DIR}; \
+-./install-sh -c -m 0755 -o root -g ${FIND_GROUP} ./apgbfm ${INSTALL_PREFIX}${APG_BIN_DIR}; \
+-./install-sh -c -m 0444 ./doc/man/apgbfm.1 ${INSTALL_PREFIX}${APG_MAN_DIR}; \
++./mkinstalldirs ${DESTDIR}/${INSTALL_PREFIX}${APG_BIN_DIR}; \
++./mkinstalldirs ${DESTDIR}/${INSTALL_PREFIX}${APG_MAN_DIR}; \
++./install-sh -c -m 0755 -o root -g ${FIND_GROUP} ./apgbfm ${DESTDIR}/${INSTALL_PREFIX}${APG_BIN_DIR}; \
++./install-sh -c -m 0444 ./doc/man/apgbfm.1 ${DESTDIR}/${INSTALL_PREFIX}${APG_MAN_DIR}; \
+ fi
+ install-cygwin:
diff --git a/app/admin/apg/apg-2.3.0b.diff b/app/admin/apg/apg-2.3.0b.diff
new file mode 100644 (file)
index 0000000..ee659c9
--- /dev/null
@@ -0,0 +1,47 @@
+diff -Naur apg-2.3.0b.orig/Makefile apg-2.3.0b/Makefile
+--- apg-2.3.0b.orig/Makefile   2003-08-07 12:40:39.000000000 -0300
++++ apg-2.3.0b/Makefile        2009-06-24 00:12:27.000000000 -0300
+@@ -1,7 +1,7 @@
+ ##################################################################
+ # Directories
+ # Install dirs
+-INSTALL_PREFIX = /usr/local
++INSTALL_PREFIX = /usr
+ # Full default path is /usr/local/bin
+ APG_BIN_DIR = /bin
+@@ -144,22 +144,22 @@
+ install:
+       if test -x ./apg; then \
+-./mkinstalldirs ${INSTALL_PREFIX}${APG_BIN_DIR}; \
+-./mkinstalldirs ${INSTALL_PREFIX}${APG_MAN_DIR}; \
+-./install-sh -c -m 0755 -o root -g ${FIND_GROUP} ./apg ${INSTALL_PREFIX}${APG_BIN_DIR}; \
+-./install-sh -c -m 0444 ./doc/man/apg.1 ${INSTALL_PREFIX}${APG_MAN_DIR}; \
++./mkinstalldirs ${DESTDIR}/${INSTALL_PREFIX}${APG_BIN_DIR}; \
++./mkinstalldirs ${DESTDIR}/${INSTALL_PREFIX}${APG_MAN_DIR}; \
++./install-sh -c -m 0755 -o root -g ${FIND_GROUP} ./apg ${DESTDIR}/${INSTALL_PREFIX}${APG_BIN_DIR}; \
++./install-sh -c -m 0444 ./doc/man/apg.1 ${DESTDIR}/${INSTALL_PREFIX}${APG_MAN_DIR}; \
+ fi
+       if test -x ./apgd; then \
+-./mkinstalldirs ${INSTALL_PREFIX}${APGD_BIN_DIR}; \
+-./mkinstalldirs ${INSTALL_PREFIX}${APGD_MAN_DIR}; \
+-./install-sh -c -m 0755 -o root -g ${FIND_GROUP} ./apgd ${INSTALL_PREFIX}${APGD_BIN_DIR}; \
+-./install-sh -c -m 0444 ./doc/man/apgd.8 ${INSTALL_PREFIX}${APGD_MAN_DIR}; \
++./mkinstalldirs ${DESTDIR}/${INSTALL_PREFIX}${APGD_BIN_DIR}; \
++./mkinstalldirs ${DESTDIR}/${INSTALL_PREFIX}${APGD_MAN_DIR}; \
++./install-sh -c -m 0755 -o root -g ${FIND_GROUP} ./apgd ${DESTDIR}/${INSTALL_PREFIX}${APGD_BIN_DIR}; \
++./install-sh -c -m 0444 ./doc/man/apgd.8 ${DESTDIR}/${INSTALL_PREFIX}${APGD_MAN_DIR}; \
+ fi
+       if test -x ./apgbfm; then \
+-./mkinstalldirs ${INSTALL_PREFIX}${APG_BIN_DIR}; \
+-./mkinstalldirs ${INSTALL_PREFIX}${APG_MAN_DIR}; \
+-./install-sh -c -m 0755 -o root -g ${FIND_GROUP} ./apgbfm ${INSTALL_PREFIX}${APG_BIN_DIR}; \
+-./install-sh -c -m 0444 ./doc/man/apgbfm.1 ${INSTALL_PREFIX}${APG_MAN_DIR}; \
++./mkinstalldirs ${DESTDIR}/${INSTALL_PREFIX}${APG_BIN_DIR}; \
++./mkinstalldirs ${DESTDIR}/${INSTALL_PREFIX}${APG_MAN_DIR}; \
++./install-sh -c -m 0755 -o root -g ${FIND_GROUP} ./apgbfm ${DESTDIR}/${INSTALL_PREFIX}${APG_BIN_DIR}; \
++./install-sh -c -m 0444 ./doc/man/apgbfm.1 ${DESTDIR}/${INSTALL_PREFIX}${APG_MAN_DIR}; \
+ fi
+ install-cygwin:
diff --git a/app/admin/apg/apg.SlackBuild b/app/admin/apg/apg.SlackBuild
new file mode 100644 (file)
index 0000000..2537a0d
--- /dev/null
@@ -0,0 +1,242 @@
+#!/bin/bash
+#
+#  apg.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.
+#
+#  apg.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 apg, by Silvio Rhatto
+# requires:  
+# tested: apg-2.3.0b
+# 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="apg"
+PKG_NAME="apg"
+ARCH=${ARCH:=i486}
+SRC_VERSION=${VERSION:=2.3.0b}
+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:="app/admin/apg"}
+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.gz"
+URL="http://www.adel.nursat.kz/apg/download/$SRC"
+
+if [ ! -s "$SRC_DIR/$SRC" ] || ! gunzip -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
+)
+
+# Install documentation
+DOCS="CHANGES COPYING README THANKS 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----------------------------------------------------------|
+apg: apg
+apg:
+apg: APG (Automated Password Generator) is the tool set
+apg: for random password generation.
+apg:
+apg:
+apg:
+apg:
+apg:
+apg:
+apg:
+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
diff --git a/dev/libs/cryptlib/Manifest b/dev/libs/cryptlib/Manifest
new file mode 100644 (file)
index 0000000..520f9ca
--- /dev/null
@@ -0,0 +1,23 @@
+-----BEGIN PGP SIGNED MESSAGE-----
+Hash: SHA256
+
+DIST cl332.zip 4236301 MD5 8736e8a78eb35a4abd3b057420357527 RMD160 e27427e2a62ff58d70e4e25c48b6b4932cae670e SHA1 c334e9b94bda14466da43ea51af3d954e9f8a511 SHA256 7757f55f59a58dfa79f400bf4e07fc30801951e6ae94b72a5eb1ea8a8925b119 SHA512 601a72b75b9cc52e350f6162c5d5e1a41c0153e9d5ac65b00efe14efe2c527de954f84a2224f2ea6bda8db4b2f32ef0eb48bd50c99f07f3e0a7ff5b8883d85b2
+MKBUILD cryptlib.mkbuild 5222 MD5 218a5f02e0a917b94afed9128077552c RMD160 03cb204a0db074584f2b51b684dc20c61013ee0c SHA1 fcd31f01427f249a3a3fce210c160c1357786572 SHA256 630fc2b1a3ad2bae15de83194088af0241386d1206bfb7d21249cdabda527dfd SHA512 f7a18b0142ef32de094c38b87e82dd1bac107ed0e2bf401842bbfcfc5eb1d4538ae823fd9bd8b74c0909e206b0fd1796b3c600af0a42a5e77648fc875ce3b16a
+SLACKBUILD cryptlib.SlackBuild 6801 MD5 8c112a4c2e251f57f30a81bcfd6ab571 RMD160 464e7673dbb283b88b92125038579e4f45e2f9a5 SHA1 6eeb9d02b2cd1a0fff05f2430d75f3dc2336cf6f SHA256 c5581551e58f7e0503b21a86c8ecc36d59172cbf3caa95a76a70b1b02f61fdd5 SHA512 ed7307f90b76a2c9313fc48da0a458bf5af21c0589d4e7593df677ce61cea90cd52338ce72804bed63d01168561993007fa6343b380446c2331512e972503e1e
+-----BEGIN PGP SIGNATURE-----
+Version: GnuPG v1.4.9 (GNU/Linux)
+
+iQIcBAEBCAAGBQJKQZMwAAoJEEHL93ESzgeitm0P/RDeb7b+uhEaFaiRgO/NGfkS
+MPeF189eiCxeC0HWNkSQvZvxbp8hklRMBeWAJ0rXfQcIHP/Iza+DPa6B2TI9pFtq
+k5FN2SUZtKP52b95x5yJpU/u64sDl21RePAVci9UhtTYH96Fw18haLXjLUTewYYx
+qy1D4ifQx6Lydqv/EBTEsYl5rqZ4ceEm5lBExarS4cYuOP5CANMp6wpRPPERQxqW
+0AewGBijV0meTmHj54QvJXgT0v8UKkZz/wqAq/3HUu7iUvoM8dTjNdtCtULFNcN9
+GRgbO3vwdxF7jZBxZdZtfI7GpmI+X7CMCnPBdDTnpJp7DWMgIU0CYrfbkFMguKZR
+YyrPg3FOKQvD/e/pV3tE01z8BhhI6525VSV9ETJu+3X0+n2b2U0CZLTA6ucnMaxj
+iJEN2mhMhi0ak3kNxabDffI/29bQw9zH7cFwOYcDPlXQGKB2h8QLIarZoemnkHyM
+8Q4y5q4aiktWkHj5/KOkCDyjeTq/954U6TQPTFVpv7P1udl6Xpf/hWJUCZyAh+4q
+wB5Tp6ocIyj/HeilyYqbOopPSzpGT6A0QfZ1fFM2KeCDIK3aYM3hiVghIgcPEHuO
+J4yuB/uusrEKckh7D90DZbwuj+FuAo4pYdILzW4nIVaS+jys/2IwfT80IXGQkLUq
+5twsxHjGyasgiUT/KEmu
+=2nJn
+-----END PGP SIGNATURE-----
diff --git a/dev/libs/cryptlib/cryptlib.SlackBuild b/dev/libs/cryptlib/cryptlib.SlackBuild
new file mode 100644 (file)
index 0000000..0742c7a
--- /dev/null
@@ -0,0 +1,220 @@
+#!/bin/bash
+#
+#  cryptlib.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.
+#
+#  cryptlib.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 cryptlib, by Silvio Rhatto
+# requires:  
+# tested: cryptlib-3.3.2
+# 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="cl332"
+PKG_NAME="cryptlib"
+ARCH=${ARCH:=i486}
+SRC_VERSION=${VERSION:=3.3.2}
+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:="dev/libs/cryptlib"}
+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.zip"
+URL="ftp://ftp.franken.de/pub/crypt/cryptlib/$SRC"
+
+if [ ! -s "$SRC_DIR/$SRC" ] || ! unzip -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"
+unzip -qoa "$SRC_DIR/$SRC" || exit $ERROR_TAR
+PKG_SRC="$PWD/`ls -l | awk '/^d/ { print $NF }'`"
+cd "$PKG_SRC"
+
+# Compile
+make $NUMJOBS || exit $ERROR_MAKE
+make $NUMJOBS shared || exit $ERROR_MAKE
+
+# Install
+mkdir -p $PKG/$PREFIX/include $PKG/$LIBDIR
+cp libcl.* $PKG/$LIBDIR
+cp cryptlib.h $PKG/$PREFIX/include
+
+# 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
+)
+
+# Install documentation
+DOCS="COPYING README"
+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-----------------------------------------------------|
+cryptlib: cryptlib
+cryptlib:
+cryptlib: cryptlib is a powerful security toolkit that allows even
+cryptlib: inexperienced crypto programmers to easily add encryption
+cryptlib: and authentication services to their software.
+cryptlib:
+cryptlib:
+cryptlib:
+cryptlib:
+cryptlib:
+cryptlib:
+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
diff --git a/dev/libs/crypto++/Manifest b/dev/libs/crypto++/Manifest
new file mode 100644 (file)
index 0000000..a02698d
--- /dev/null
@@ -0,0 +1,25 @@
+-----BEGIN PGP SIGNED MESSAGE-----
+Hash: SHA256
+
+DIST cryptopp560.zip 1049029 MD5 36f35789ad60489d58003d3c849807e8 RMD160 82e5061ec76f23643ba5477ab28bbee6eebd393a SHA1 b836783ebd72d5bc6a916620ab2b1ecec316fef1 SHA256 b522f0b5f850b50e9917823ea986f855295407380fafbe30f358875c41998bc5 SHA512 37c5820404f9fa94e4ebe595865de17af13876bf5ef20c8612e019427893227f80095f21ee71c6caf781f14a493dc56805eb965e909f8fdce31a9f748b772655
+MKBUILD crypto++.mkbuild 4888 MD5 83eb8faf66a3986ade92830064d65dec RMD160 8bc1c17a08f84396948f342aa2b5ff44c94c71b3 SHA1 4ab9bce83256cbc73d996b328b414d20b6b770b5 SHA256 a7834591b48417c11376cc37e293337d8bc164284936cf4ef6db6a1571ce6864 SHA512 cdf93ffd7866ae8444ff5cd78dbdac4b05430a1ff0f780fb2ba75de59d1dd6a650c13810499696a995a9fac56d9aa2087a91bdd323c97c1c7f4d54f9ad09997c
+PATCH crypto++-5.6.0.diff 874 MD5 0989bd8c3ec337960da4dfa78850d52a RMD160 2f30346b8fd6c5009eb434f1c7f1bd7b3ff6471a SHA1 f92dd203eef21bcae39853ded75d71a5f16697fe SHA256 4eb366c61ee5454fb575f063ed7528c197eeed6a4f80a479144724182c290531 SHA512 8636fff50b472c30d8d297303e91614606bd36d643f7a94eef652c394026472316cca28158e571bc6089ddda66ec9f7280e727e5e3ed2ac5ccae5ec14d11f127
+PATCH crypto++.5.6.0.diff 874 MD5 0989bd8c3ec337960da4dfa78850d52a RMD160 2f30346b8fd6c5009eb434f1c7f1bd7b3ff6471a SHA1 f92dd203eef21bcae39853ded75d71a5f16697fe SHA256 4eb366c61ee5454fb575f063ed7528c197eeed6a4f80a479144724182c290531 SHA512 8636fff50b472c30d8d297303e91614606bd36d643f7a94eef652c394026472316cca28158e571bc6089ddda66ec9f7280e727e5e3ed2ac5ccae5ec14d11f127
+SLACKBUILD crypto++.SlackBuild 7612 MD5 b6d316efc66d15a8ad84fb32a0191845 RMD160 38706a570bcb9d5f5459c11dd7f3822fbe3a7d1a SHA1 c92c5dfc7a9e682067b049f22d0309e5380ed783 SHA256 e6c87ad65b3cd9fe9830d3ac4f3bd4a15481262c3199742637b73a72d8023042 SHA512 d92fedb1d63a84e34dbdaf0cbee35cdedc4235e99c28a2dfcbe6b5d9bc85ee305f291d1cbb05884e6755b13b233f1cb4c942dcd3853957c44953a134b1ab7a38
+-----BEGIN PGP SIGNATURE-----
+Version: GnuPG v1.4.9 (GNU/Linux)
+
+iQIcBAEBCAAGBQJKQaVTAAoJEEHL93ESzgeiNecP/iwP2P21ArJHRpADWnFL77f3
+oi/q0bhmCVfcH/75Pkw9prixQjeOdQ+IYhDDPQIZvvLUjt9nPz/86UXGQANkDxOq
+jxAxDCUdpdkLx8GEffkjpSjovwn9xCwSiAoctB0wQcboxBJucrjPPxXOJWWsdZv7
+rBDtWsRjj1uPfAZG+euujgECHEuCv479WwBh3ePfVQMvesxPHYW+pJVRJ+cKdru1
+DsC6Nv1APs7zj68ZbYV6s2HV8iSbI/KSMWN2OGDzoj7gxmGi4t3thIq5nBXK1QB7
+fW/nbjqfPhcVPr9dmubD02wT8FuHaQ6Af1Yc+imFB013jVQaImyASsjSXGGbuoyR
+nQSGvkMSi9LT7F+Ybr52SJVXi5n2mD0cjPvhDH8RH5qsUl2sMNYW+hkQGQH5mZlj
+5mrFgnR9b7psA/rls3rRTYqx2KuTMLb7wPbmF3K/hxdcbPZBOHGPez6w2pF1v/I0
+pQ6cRURzpPKLr4U/i5zSc7ArZYMOuCyoU1aG1D+AEPrEinxIBKnSOLuO9LZeSVqI
+nlDGiQfPua6PoQczx0SGqPRpkNKXlsuE1VSkCgMjSp1ydwr93tpDzW9eFLXHhOUk
+yw3GrAIdI7zBr3HkMfcuDa2XevYw9aUupicvgJpE6I6GANH6Rn8GDlDObf9+hMzb
+uUwu7vHZImFa/+xXCt+4
+=nnc1
+-----END PGP SIGNATURE-----
diff --git a/dev/libs/crypto++/crypto++-5.6.0.diff b/dev/libs/crypto++/crypto++-5.6.0.diff
new file mode 100644 (file)
index 0000000..41a4507
--- /dev/null
@@ -0,0 +1,18 @@
+diff -Naur cryptopp.orig/GNUmakefile cryptopp/GNUmakefile
+--- cryptopp.orig/GNUmakefile  2009-03-15 02:48:02.000000000 -0300
++++ cryptopp/GNUmakefile       2009-06-24 00:27:45.000000000 -0300
+@@ -118,10 +118,10 @@
+       $(RM) cryptest.exe libcryptopp.a $(LIBOBJS) $(TESTOBJS) cryptopp.dll libcryptopp.dll.a libcryptopp.import.a cryptest.import.exe dlltest.exe $(DLLOBJS) $(LIBIMPORTOBJS) $(TESTIMPORTOBJS) $(DLLTESTOBJS)
+ install:
+-      $(MKDIR) -p $(PREFIX)/include/cryptopp $(PREFIX)/lib $(PREFIX)/bin
+-      $(CP) *.h $(PREFIX)/include/cryptopp
+-      $(CP) *.a $(PREFIX)/lib
+-      $(CP) *.exe $(PREFIX)/bin
++      $(MKDIR) -p $(DESTDIR)/$(PREFIX)/include/cryptopp $(DESTDIR)/$(PREFIX)/lib $(DESTDIR)/$(PREFIX)/bin
++      $(CP) *.h $(DESTDIR)/$(PREFIX)/include/cryptopp
++      $(CP) *.a $(DESTDIR)/$(PREFIX)/lib
++      $(CP) *.exe $(DESTDIR)/$(PREFIX)/bin
+ libcryptopp.a: $(LIBOBJS)
+       $(AR) $(ARFLAGS) $@ $(LIBOBJS)
diff --git a/dev/libs/crypto++/crypto++.SlackBuild b/dev/libs/crypto++/crypto++.SlackBuild
new file mode 100644 (file)
index 0000000..0ba3f75
--- /dev/null
@@ -0,0 +1,242 @@
+#!/bin/bash
+#
+#  crypto++.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.
+#
+#  crypto++.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 crypto++, by Silvio Rhatto
+# requires:  
+# tested: crypto++-5.6.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="cryptopp560"
+PKG_NAME="crypto++"
+ARCH=${ARCH:=i486}
+SRC_VERSION=${VERSION:=5.6.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:="dev/libs/crypto++"}
+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.zip"
+URL="http://downloads.sourceforge.net/cryptopp/$SRC"
+
+if [ ! -s "$SRC_DIR/$SRC" ] || ! unzip -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"
+unzip -qoa "$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
+)
+
+# Install documentation
+DOCS="License.txt Readme.txt"
+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-----------------------------------------------------|
+crypto++: crypto++
+crypto++:
+crypto++: Crypto++ Library is a free C++ class library of
+crypto++: cryptographic schemes.
+crypto++:
+crypto++:
+crypto++:
+crypto++:
+crypto++:
+crypto++:
+crypto++:
+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
diff --git a/net/p2p/amule/Manifest b/net/p2p/amule/Manifest
new file mode 100644 (file)
index 0000000..d73eddc
--- /dev/null
@@ -0,0 +1,24 @@
+-----BEGIN PGP SIGNED MESSAGE-----
+Hash: SHA256
+
+DIST aMule-2.2.5.tar.bz2 4715858 MD5 d26048f8e00a1ca801b3b41156b4268d RMD160 cef2ea2248b877c75dce6a8f4c32c7585c5f64b8 SHA1 2e58fdeffe65cd036467b1c62ba95d791fba9a11 SHA256 cb2ec9885037fe114999374368b1c16038ccd8a2eeda16231eea4096a7b2befd SHA512 18509992177d805e468ee1be568a79464989862974ad800ad88927f54f140cb966c8c2254f3acf0c0cc3c55e320cd7c1d839a990ad96219885af7b34adcecd1b
+MKBUILD aMule.mkbuild 5183 MD5 9587c83bdb015bd76a6cdfa377288e5c RMD160 46951b683a80200589b81693b56f56e8a800d2b5 SHA1 7d102c275b781ad89751e626e99ccea3571fd6ab SHA256 bf905df70d46c5c362159be13ea18b414b99f62b26d7a4364f47547635389c67 SHA512 e0bd2f6eb452d971a1eed0c13ca451c8e99c3be8e8434a87c803937549351efd30112055fb2cc23542c1f6b7fb962dafcb0fac5c1cb3239756097a2ebed894c8
+SLACK-REQUIRED slack-required 78 MD5 802af14459d902427492a896ba7c1ce7 RMD160 69f577778740e71c20a36ddc309f0b854a07f2f8 SHA1 ecec5edfade2be35cc00bd1c89676796e90b790c SHA256 24e35411eb040e06981f99fa1564efdf3f4430fc37eae94810375d2d49fb13d6 SHA512 b8d194b6d8e7ec6fbd38b789f8422157269cf08f19d2b4bf9472886df52c4decd659fa738b3e51a1f1ce64bd673c5182c342bf5d158754da48c4c2fb19193a25
+SLACKBUILD aMule.SlackBuild 7218 MD5 28b83def6558928422a3a8ebb9a71c05 RMD160 d8bf02031d4f8d498a63d5c93ead1af64cae334a SHA1 3877818daefc4be8ac965b7dec45b07b818875e6 SHA256 e2a6d13eec6d10aaf9c6d19d4400c5b4e5cac18dcd906840c068a1add920cf95 SHA512 819f2faa3cbc8b31ea2ec9aa373b6d5a966207ca9de1b62ae225fa57d1fe47a754d1462acd3eea29437e4d2b11c56a5125790b1984787993479b393b9211163e
+-----BEGIN PGP SIGNATURE-----
+Version: GnuPG v1.4.9 (GNU/Linux)
+
+iQIcBAEBCAAGBQJKQaQ+AAoJEEHL93ESzgei1UYP/2ena41cg7MD4bm7USJTKBFc
+eCDAEMkoL7XElAkPcG+aZyv4exi/jy+Hlda7DSX+M89n2Rfx2IYLo6PYwGf1G1HF
+VKCcfqnG3J2ls+08G6zUFsLa2dYJU5EywMSGK4mPOoa9miRCCkgGbTf0pwkpSYGk
+3BdAS13m9rzLPQVo8I1ML5RGF4f3HA+cW5E5yNpkRTUwLUttCulYwTZ2tJOqVgLW
+RMS4jNg9nTbsraDWXv7Dei5tjRQvfouixh3ETCDUB/mtlZ6NYLDhj7VCWlZT6IYr
+tvdTXRz+W+rio+9nAVaPMcLu8oU7mjR/1u0aglIHdEIvhdw9h3Azyh5iOfQhtgVe
+s/vzk58R5PZBf8alsstgYQ79nIdNSH/bdwNK4NPd7JCr2LowgshMhwyi5mLZDbvz
+D9lvJWzdaczsR9tM8/uHsBAmh1DZkqD/iEq6xtwHFHfn3mwuu+EbL67BjHX/Vbx+
+X5eLXlj7jIyaLNywqbi91G0x5LipuIt4F/iT/PW1XnJrq3Eb+so+9QHlqB7WKDuD
+Ydaur3x0fEv5kp251FjF0k54yyv/rhRKrM4VtvcnXgaJM5M8Sj80WlHZ4XFlFXBF
+PnXBw2Bc09wYoN9Rer/hgQUfVihsJzw5Nu/v3y5M9YAZNGqFA2KnYCVlEtAyrqk6
+rQiCp2TdLEjotawhX+87
+=COjI
+-----END PGP SIGNATURE-----
index 139f12ac9a817b16693628d97402ad219b52369d..496bf3c8c2a997f3d21f6fe05224a504d19bac38 100755 (executable)
 #!/bin/bash
 #
-#  aMule.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.
+#  aMule.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.
 #
-#  aMule.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.
+#  aMule.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
+#  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 script for aMule
-# by rhatto at riseup.net
+# slackbuild for aMule, by Silvio Rhatto
+# requires: crypto++ 
+# tested: aMule-2.2.5
+# model: generic.mkSlackBuild $Rev: 805 $
 #
 
-CWD="`pwd`"
-
+# Look for slackbuildrc
 if [ -f ~/.slackbuildrc ]; then
   source ~/.slackbuildrc
 elif [ -f /etc/slackbuildrc ]; then
   source /etc/slackbuildrc
 fi
 
-# default settings
-PACKAGE="aMule"
+# Set variables
+CWD="$(pwd)"
+SRC_NAME="aMule"
+PKG_NAME="aMule"
 ARCH=${ARCH:=i486}
-VERSION=${VERSION:=2.1.3}
+SRC_VERSION=${VERSION:=2.2.5}
+PKG_VERSION="$(echo "$SRC_VERSION" | tr '[[:blank:]-]' '_')"
 BUILD=${BUILD:=1rha}
-SRC_DIR=${SRC:=$CWD}
+SRC_DIR=${SRC_DIR:=$CWD}/$PKG_NAME
 TMP=${TMP:=/tmp}
+PKG=${PKG:=$TMP/package-$PKG_NAME}
 REPOS=${REPOS:=$TMP}
-
-if [ "$ARCH" == "x86_64" ]; then
-  LIBDIR=/usr/lib64
-else
-  LIBDIR=/usr/lib
+SLACKBUILD_PATH=${SLACKBUILD_PATH:="net/p2p/amule"}
+PREFIX=${PREFIX:=/usr}
+PKG_WORK="$TMP/$SRC_NAME"
+CONF_OPTIONS=${CONF_OPTIONS:="--sysconfdir=/etc --enable-amulecmd"}
+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
 
-RTOOL="wget"
-PACKAGE_EXT="bz2"
-SRC="$PACKAGE-$VERSION.tar.$PACKAGE_EXT"
-URL="http://easynews.dl.sourceforge.net/sourceforge/amule/$SRC"
-
-SRC_DIR="$SRC_DIR/$PACKAGE"
-mkdir -p $SRC_DIR
-
-if [ "$PACKAGE_EXT" == "bz2" ]; then
-  tarflag="j"
-else
-  tarflag="z"
-fi
-
-if [ "$RTOOL" == "wget" ] && [ ! -f "$SRC_DIR/$SRC" ]; then
-  wget "$URL" -O "$SRC_DIR/$SRC"
+# 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://downloads.sourceforge.net/amule/$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
 
-TMP="$TMP/$PACKAGE"
-rm -rf $TMP
-mkdir -p $TMP
-cd $TMP
-
-tar xvf$tarflag $SRC_DIR/$SRC
-cd $PACKAGE-$VERSION
+# 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
 
-if [ -f "$CWD/$PACKAGE-$VERSION.diff" ]; then
-  patch -p1 < $CWD/$PACKAGE-$VERSION.diff
+else
+  exit $ERROR_MANIFEST
 fi
 
-./configure --prefix=/usr --sysconfdir=/etc --libdir=$LIBDIR --enable-amulecmd
-make || exit 32
-make DESTDIR=$TMP/package-$PACKAGE install
-
-CWD="`pwd`"
-
-cd $TMP/package-$PACKAGE
-
-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
+# 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"
+
+# Configure
+CFLAGS="$SLKCFLAGS" \
+  CXXFLAGS="$SLKCFLAGS" \
+  ./configure \
+  --prefix="$PREFIX" --libdir="$LIBDIR" $CONF_OPTIONS || exit $ERROR_CONF
+
+# 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
+)
+
+# Install documentation
+DOCS="NEWS TODO README AUTHORS INSTALL ChangeLog MAINTAINERS COPYING LICENSE SIGNATURE readme.*"
+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
 
-mkdir install
-cat << EOF > install/slack-desc
+# 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
+# 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
+# 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-----------------------------------------------------|
+     |-----handy-ruler--------------------------------------------------------|
 aMule: aMule (A multi-platform eMule-like ed2k client)
 aMule:
 aMule: aMule is short for "all-platform eMule-like file-sharing program",
@@ -101,18 +210,14 @@ aMule: a running aMule via the network.
 aMule:
 aMule:
 aMule:
-EOF
+EODESC
 
-# docs
-mkdir -p usr/doc/$PACKAGE-$VERSION
+# 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
 
-for file in ABOUT-NLS AUTHORS COPYING Changelog Doxyfile ED2K-Links.HOWTO README; do
-  cp $CWD/docs/$file* usr/doc/$PACKAGE-$VERSION/
-done
-
-makepkg -c y -l y $REPOS/$PACKAGE-$VERSION-$ARCH-$BUILD.tgz
-
-if [ "$CLEANUP" == "yes" ]; then
-  rm -rf $TMP
+# Delete source and build directories if requested
+if [ "$CLEANUP" == "yes" ] || [ "$1" = "--cleanup" ]; then
+  rm -rf "$PKG_WORK" "$PKG"
 fi
-
index fe65c28091a0e63abf7cd9d97663bb0ed8f675cd..37cf29d1881b9667baa67eb3c050cd5e3753df57 100644 (file)
@@ -1,2 +1,4 @@
-libiconv
-wxWidgets
+# Dependency list to aMule
+#
+# dependency [condition] [version]]
+crypto++