]> gitweb.fluxo.info Git - slackbuilds.git/commitdiff
kino: updating to 1.3.2 and adding Manifest
authorrhatto <rhatto@370017ae-e619-0410-ac65-c121f96126d4>
Sat, 17 Jan 2009 16:40:27 +0000 (16:40 +0000)
committerrhatto <rhatto@370017ae-e619-0410-ac65-c121f96126d4>
Sat, 17 Jan 2009 16:40:27 +0000 (16:40 +0000)
git-svn-id: svn+slack://slack.fluxo.info/var/svn/slackbuilds@2087 370017ae-e619-0410-ac65-c121f96126d4

games/strategy/dopewars/Manifest [new file with mode: 0644]
games/strategy/dopewars/dopewars.SlackBuild
mail/mta/ssmtp/Manifest
mail/mta/ssmtp/ssmtp.SlackBuild
mail/mta/ssmtp/sstmp.SlackBuild
media/video/kino/Manifest [new file with mode: 0644]
media/video/kino/kino.SlackBuild
media/video/kino/slack-required

diff --git a/games/strategy/dopewars/Manifest b/games/strategy/dopewars/Manifest
new file mode 100644 (file)
index 0000000..ae0abc1
--- /dev/null
@@ -0,0 +1,4 @@
+DIST dopewars-1.5.12.tar.gz 1419725 MD5 debf749de9053dc2fb2e74c37ae06206 RMD160 66c86bceb67657a9fb2ef7944b1a069dafab8ae0 SHA1 ad46a38e225680e591b078eeec563d47b96684bc SHA256 23059dcdea96c6072b148ee21d76237ef3535e5be90b3b2d8239d150feee0c19 SHA512 cfabaf9326c847aed6210a852ace64c697df5845a66b3179b8dc8dea7b99a11e1f91358d4ee54929a56c70d5f3a76f9f7bb4079fdef765601f165b4cd06cba5a
+MISC dopewars.key 1312 MD5 6b604deb4e50516d3ba73f1e14dba0e7 RMD160 b62f962ffb5e78218b07c2e7944fa586034b0311 SHA1 31cb8f6ed3acfa7a0a7e6a98c9269080000b9bc7 SHA256 bcc13a83d7db3f746cea0ed1df987f61e95bd0ae27dead43846121fc5a9b3bf3 SHA512 82d9169508a03ab509743257590e4b79616a33d93a52466eb4a26cd80a4e9ea903dfe3cc51f23875be21cee6f9d315442ff4c3906a1a31c63a2560f1fa17efc8
+MKBUILD dopewars.mkbuild 3025 MD5 5fe6cefd1c221873d09b27641762813b RMD160 981cd3403ccbafb03b5678451b54ba79a374c6c2 SHA1 ae744934512e052de7f61d3d3f95debc6597661d SHA256 34201832c2192c84af072dd87933c862992eab77d7c6dc3f2383cae002758100 SHA512 8bb314185f51a59b58918024589bf44e917836231f8bb567303690e77a709d06dfbd93403b8d2a7d6799d2abf483e6a6b68cbd42f09262a59dcd5173d36c3a81
+SLACKBUILD dopewars.SlackBuild 8310 MD5 f1fefdadb9342c6feefac408b60e70ed RMD160 e71221109da4bacfc832fae31501939950cb9dea SHA1 d72e2663605b1aff69fad81a032f57afe3135153 SHA256 7443d8f331ffa3abd65845c1d6ac5cbebb5e21d01d95b22270395ab80f3ba80a SHA512 eed4236df297a3e5fa67e833771d719034ac5a0ac463e3d087b3a8c8d68bc677ef2d38b325940fb7f46d1410020601adb3c90131508d4ec93edab75a1d2c63ef
index 07f07792e6fad46773ac6b38d7501d050ac10248..6e246aa234519645fab6036b6a57e043088a96ec 100755 (executable)
@@ -10,9 +10,9 @@
 #  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 for dopewars, by Silvio Rhatto
 # requires:  
@@ -47,16 +47,17 @@ NUMJOBS=${NUMJOBS:=""}
 LIBDIR="$PREFIX/lib"
 
 if [ "$ARCH" = "i386" ]; then
-  SLKCFLAGS="-O2 -march=i386 -mcpu=i686"
+  SLKCFLAGS="-O2 -march=i386 -mtune=i686"
 elif [ "$ARCH" = "i486" ]; then
-  SLKCFLAGS="-O2 -march=i486 -mcpu=i686"
+  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"
+  SLKCFLAGS="-O2 -fPIC"
   LIBDIR="$PREFIX/lib64"
+  LDFLAGS="-L/lib64 -L/usr/lib64"
 fi
 
 # Set error codes (used by createpkg)
@@ -64,6 +65,7 @@ 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
@@ -86,6 +88,8 @@ fi
 # Import minimized signing key from
 if echo [[SIGNING KEY URL]] | grep -q -v "SIGNING KEY URL"; then
   lynx -dump [[SIGNING KEY URL]] | gpg --import || exit $ERROR_GPG
+elif echo [[SIGNING KEY ID]] | grep -q -v "SIGNING KEY ID"; then
+  gpg --recv-keys [[SIGNING KEY ID]] || exit $ERROR_GPG
 else
   gpg --import << EOKEY || exit $ERROR_GPG
 `cat dopewars.key`
@@ -99,9 +103,9 @@ if echo http://downloads.sourceforge.net/dopewars/dopewars-1.5.12.tar.gz.gpg | g
     wget "http://downloads.sourceforge.net/dopewars/dopewars-1.5.12.tar.gz.gpg" -O "$SRC_DIR/$SIGNATURE" || exit $ERROR_WGET
   fi
 else
-  if [ -f "$SRC_DIR/$SRC.sig" ]; then
+  if [ -s "$SRC_DIR/$SRC.sig" ]; then
     SIGNATURE="$SRC.sig"
-  elif [ -f "$SRC_DIR/$SRC.asc" ]; then
+  elif [ -s "$SRC_DIR/$SRC.asc" ]; then
     SIGNATURE="$SRC.asc"
   else
     echo Trying to get signature file from $URL.sig...
@@ -125,10 +129,67 @@ echo Checking $SRC_DIR/$SRC with gpg using $SRC_DIR/$SIGNATURE...
 gpg --verify "$SRC_DIR/$SIGNATURE" "$SRC_DIR/$SRC" || exit $ERROR_GPG
 echo Success.
 
+# Check Manifest file
+if [ -e "$CWD/Manifest" ]; then
+
+  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 $8 }'`"
+PKG_SRC="$PWD/`ls -l | awk '/^d/ { print $NF }'`"
 cd "$PKG_SRC"
 
 # Configure
@@ -152,7 +213,7 @@ make install DESTDIR="$PKG" || exit $ERROR_INSTALL
 )
 
 # Install documentation
-DOCS="NEWS TODO README AUTHORS INSTALL ChangeLog MAINTAINERS COPYING readme.*"
+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
@@ -164,9 +225,9 @@ done
 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 ':'.
 
@@ -189,6 +250,6 @@ cd "$PKG"
 makepkg -l y -c n "$REPOS/$PKG_NAME-$PKG_VERSION-$ARCH-$BUILD.tgz" || exit $ERROR_MKPKG
 
 # Delete source and build directories if requested
-if [ "$CLEANUP" == "yes" ]; then
+if [ "$CLEANUP" == "yes" ] || [ "$1" = "--cleanup" ]; then
   rm -rf "$PKG_WORK" "$PKG"
 fi
index cf0cc0ebbc2f00a356b9af2c9849498333e5fec3..a693da2cc4a193c335e78c23a5cac1646ac10d04 100644 (file)
@@ -1,3 +1,4 @@
-DIST sstmp_VERSION.orig.tar.gz 53341 MD5 957e6fff08625fe34f4fc33d0925bbc9 RMD160 da76ee6dd86fc663e6fd69fcb2fb5f550f716de7 SHA1 bc4b6c20bf8c2c9e66b359e3c24545a2615a1988 SHA256 2151ad18cb73f9a254f796dde2b48be7318b45410b59fedbb258db5a41044fb5 SHA512 d359da461aa8e78fd274de7787f5b682ec53b71bc077e015ea268741a79d0c82849b94543c7c4caa6ad6c97366be0077bfa3e9fb765f2097dd76ca9e1d6ba413
-MKBUILD ssmtp.mkbuild 4316 MD5 0052b417fb0697f346c5735cf48956cb RMD160 2a6ae028d7136efd9b00867a60ef210b9d97ef2e SHA1 e7e837b5b54b0c0471878e6afb1009a135690e8e SHA256 bbc9c0d81b91d13459aa8f5a50173f470141d2a310787c736ef941cd05906f8e SHA512 0217afc638d4c010eeb76f6078502f64449b8702de7a38918f55486b3f4ff71d57c22f65e19a600784c7b5b6d9e0e7f1fe9705d5e85af1c6060abb9d28bf82c6
-SLACKBUILD sstmp.SlackBuild 8230 MD5 5061a3189178abc5b2ef40ed859f7aff RMD160 27dc5ced1e8f3e9f304648622254967a7a044c5c SHA1 32a53b4a1fe9dd2ef3c14eacebfdb220a5e23888 SHA256 8aa7b1d33973ae4761f09aaaa5c7de4f21ef3fc99bbc7ca026c97d3fcd7b57f6 SHA512 be90a0c279dde6da78bf83843ab1be12fa075d9704b8a310bb56d4fee834a39c886c6ed149338bd07ab25b06af389e0d180f3ebebae95775201344287872d8d3
+DIST ssmtp_6.61.orig.tar.gz 53341 MD5 957e6fff08625fe34f4fc33d0925bbc9 RMD160 da76ee6dd86fc663e6fd69fcb2fb5f550f716de7 SHA1 bc4b6c20bf8c2c9e66b359e3c24545a2615a1988 SHA256 2151ad18cb73f9a254f796dde2b48be7318b45410b59fedbb258db5a41044fb5 SHA512 d359da461aa8e78fd274de7787f5b682ec53b71bc077e015ea268741a79d0c82849b94543c7c4caa6ad6c97366be0077bfa3e9fb765f2097dd76ca9e1d6ba413
+MKBUILD ssmtp.mkbuild 4297 MD5 8a94b79da3af88ce5644290fa83fbaaf RMD160 f166dfb218b0c4525ced5bce97004d5fa640c698 SHA1 b75b3fd3d0bae067f95779dd2e85f102dc76e32a SHA256 c5524ff781b2b420047ee6c776482f79db6b0f0e069c8043ad113d470a14b394 SHA512 1d1154d35da725bcd9a67f61d4611b5eae9c748a53d9ab6759cdd851a0933111a502e1994e33837f30be40b68009c761dddf20882c1733114ce3b8f9be094910
+SLACKBUILD ssmtp.SlackBuild 8211 MD5 50558cfa58a402300e5815caf1044ed5 RMD160 9841c8f6c5c5a96e04c866ba12cc2e1550dffc11 SHA1 eeec9f7ea222d8d89198fc2af0fb44bb9baf3b38 SHA256 aab7e708f85bc90cbc58b3396cb45dd1362862aa24dfbbbb409da918139eae81 SHA512 4e7fcd1114b7599c24d4b94c5cc61c569f0204689e4713b3228e716fbcd74a194a8a21dd5078d652c74d661f635f5396cf9e6f619a92c08608b8fd6f319bdc92
+SLACKBUILD sstmp.SlackBuild 8231 MD5 04141d8dbab003cb71557e76bdb54cb0 RMD160 f977ca5092f960f063bb070c8c1ba12e945d27dc SHA1 dc5a8cf1edce719ea8c28b979da41484565aca4e SHA256 4731651f864654353f703b23c124b56c237a1af2f71e4020b53cc67c6e9e5e25 SHA512 17a037db335ce35095d44bd294340bc5127d11b7bf72d7b0cd0cee9e275dc7616d4067b74e18bb03b48dc44a43afd6001c37c76e1f33d4835960fb468e01e567
index b42853437cfd3861cdc0a1d856edea2ed70d146b..76d5c523a4c42cd68cc4c57465420f3572e31f86 100755 (executable)
 #!/bin/bash
 #
-#  ssmtp.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.
+#  ssmtp.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.
 #
-#  ssmtp.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.
+#  ssmtp.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 ssmtp
-# by rhatto at riseup.net
+# slackbuild for ssmtp, by Silvio Rhatto
+# requires:  
+# tested: ssmtp-6.61
 #
 
-CWD="`pwd`"
-
+# Look for slackbuildrc
 if [ -f ~/.slackbuildrc ]; then
   source ~/.slackbuildrc
 elif [ -f /etc/slackbuildrc ]; then
   source /etc/slackbuildrc
 fi
 
-# default settings
-PACKAGE="ssmtp"
+# Set variables
+CWD="$(pwd)"
+SRC_NAME="ssmtp"
+PKG_NAME="ssmtp"
 ARCH=${ARCH:=i486}
-VERSION=${VERSION:=2.61}
-BUILD=${BUILD:=4rha}
-SRC_DIR=${SRC:=$CWD}
+SRC_VERSION=${VERSION:=6.61}
+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}
+PREFIX=${PREFIX:=/usr}
+PKG_WORK="$TMP/$SRC_NAME"
+CONF_OPTIONS=${CONF_OPTIONS:=""}
+NUMJOBS=${NUMJOBS:=""}
 
-if [ "$ARCH" == "x86_64" ]; then
-  LIBDIR=/usr/lib64
-else
-  LIBDIR=/usr/lib
+# 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="gz"
-SRC="$PACKAGE"_"$VERSION.orig.tar.$PACKAGE_EXT"
-URL="http://ftp.debian.org/debian/pool/main/s/ssmtp/$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;
 
-if [ "$PACKAGE_EXT" == "bz2" ]; then
-  tarflag="j"
-else
-  tarflag="z"
-fi
+# 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
 
-SRC_DIR="$SRC_DIR/$PACKAGE"
-mkdir -p $SRC_DIR
+# Dowload source if necessary
+SRC="$SRC_NAME"_"$VERSION.orig.tar.gz"
+URL="http://ftp.de.debian.org/debian/pool/main/s/ssmtp/$SRC"
 
-if [ "$RTOOL" == "wget" ] && [ ! -f "$SRC_DIR/$SRC" ]; then
-  wget "$URL" -O "$SRC_DIR/$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
 
-TMP="$TMP/$PACKAGE"
-rm -rf $TMP
-mkdir -p $TMP/package-$PACKAGE
-cd $TMP
+# Check Manifest file
+if [ -e "$CWD/Manifest" ]; then
+
+  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..."
 
-tar xvf$tarflag $SRC_DIR/$SRC
-cd $PACKAGE-$VERSION
-./configure --prefix=/usr --sysconfdir=/etc --libdir=$LIBDIR
-make || exit 32
+    SIZE_SRC="`wc -c $MANIFEST_FILE | awk '{ print $1 }'`"
+    SIZE_MANIFEST="`echo $MANIFEST_LINE | awk '{ print $3 }'`"
 
-CWD="`pwd`"
+    # 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
 
-cd $TMP/package-$PACKAGE
+    # 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
 
-mkdir -p usr/{sbin,man/man8}
-mkdir -p etc/ssmtp
+  done
 
-cp $CWD/ssmtp usr/sbin ; chmod 755 usr/sbin/ssmtp
-cp $CWD/ssmtp.8 usr/man/man8 ; chmod 644 usr/man/man8/ssmtp.8
-cp $CWD/ssmtp.conf etc/ssmtp/ssmtp.conf.new
-cp $CWD/revaliases etc/ssmtp/revaliases.conf.new
+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"
+
+# Configure
+CFLAGS="$SLKCFLAGS" \
+  CXXFLAGS="$SLKCFLAGS" \
+  ./configure \
+  --prefix="$PREFIX" --libdir="$LIBDIR" $CONF_OPTIONS || exit $ERROR_CONF
+
+# Compile
+make $NUMJOBS || exit $ERROR_MAKE
+
+# Install
+mkdir -p $PKG/usr/{sbin,man/man8}
+mkdir -p $PKG/etc/ssmtp
+cp ssmtp $PKG/usr/sbin ; chmod 755 $PKG/usr/sbin/ssmtp
+cp ssmtp.8 $PKG/usr/man/man8 ; chmod 644 $PKG/usr/man/man8/ssmtp.8
+cp ssmtp.conf $PKG/etc/ssmtp/ssmtp.conf.new
+cp revaliases $PKG/etc/ssmtp/revaliases.conf.new
 
-strip --strip-unneeded usr/sbin/ssmtp
+# 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
+)
 
-mkdir install
-cat << EOF > install/slack-desc
+# Install documentation
+DOCS="CHANGELOG_OLD COPYING INSTALL README TLS"
+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
+# 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--------------------------------------------------------|
 ssmtp: ssmtp (extremely simple MTA)
 ssmtp:
 ssmtp: This is sSMTP, a program that replaces sendmail on workstations
@@ -102,27 +204,56 @@ ssmtp: one.
 ssmtp:
 ssmtp:
 ssmtp:
-EOF
+EODESC
 
-# docs
-mkdir -p usr/doc/$PACKAGE-$VERSION
+# Add a post-installation script (doinst.sh)
+mkdir -p "$PKG/install" || exit $ERROR_MKDIR
+cat << EOSCRIPT > "$PKG/install/doinst.sh"
+config() {
+  NEW="\$1"
+  OLD="\$(dirname \$NEW)/\$(basename \$NEW .new)"
+  OLD="\$(dirname \$NEW)/\$(basename \$OLD .sample)"
+  OLD="\$(dirname \$NEW)/\$(basename \$OLD .dist)"
 
-for file in CHANGELOG_OLD COPYING INSTALL README TLS; do 
-  cp $CWD/$file* usr/doc/$PACKAGE-$VERSION/
-done
+  # If there's no config file by that name, mv it over:
+  if [ ! -r \$OLD ]; then
+    mv \$NEW \$OLD
+  elif [ "\$(cat \$OLD | md5sum)" = "\$(cat \$NEW | md5sum)" ]; then
+    # toss the redundant copy
+    rm \$NEW
+  fi
+  # Otherwise, we leave the .new copy for the admin to consider...
+}
 
-# install script
-echo '( if [ ! -f "etc/ssmtp/ssmtp.conf" ]; then mv etc/ssmtp/ssmtp.conf.new etc/ssmtp/ssmtp.conf; fi )' > install/doinst.sh
-echo '( if [ ! -f "etc/ssmtp/revaliases" ]; then mv etc/ssmtp/revaliases.conf.new etc/ssmtp/revaliases; fi )' >> install/doinst.sh
-echo '( cd usr/man/man8 ; rm -rf sendmail.8.gz )' >> install/doinst.sh
-echo '( cd usr/man/man8 ; ln -sf .gz sendmail.8.gz )' >> install/doinst.sh
-echo '( cd usr/sbin ; rm -rf sendmail )' >> install/doinst.sh
-echo '( cd usr/sbin ; ln -sf ssmtp sendmail )' >> install/doinst.sh
-echo '( cd usr/lib ; ln -sf ../sbin/ssmtp sendmail )' >> install/doinst.sh
+mkgroup() {
+  GROUP="\$1"
+  if ! grep -qe "^\$GROUP:" etc/group; then
+    echo Creating group \$GROUP...
+    chroot . /usr/sbin/groupadd \$GROUP
+  fi
+}
 
-makepkg -c y -l y $REPOS/$PACKAGE-$VERSION-$ARCH-$BUILD.tgz
+mkuser() {
+  USER="\$1"
+  if [ ! -z "\$2" ]; then
+    GROUP="\$2"
+  else
+    GROUP="\$USER"
+  fi
+  if ! grep -qe "^\$USER:" etc/passwd; then
+    echo Creating user \$USER...
+    chroot . /usr/sbin/useradd \$USER -g \$GROUP
+  fi
+}
 
-if [ "$CLEANUP" == "yes" ]; then
-  rm -rf $TMP
-fi
+config etc/ssmtp/ssmtp.conf.new ; config etc/ssmtp/revaliases.conf.new ; ( cd usr/man/man8 ; rm -rf sendmail.8.gz ) ; ( cd usr/man/man8 ; ln -sf .gz sendmail.8.gz ) ; ( cd usr/sbin ; rm -rf sendmail ) ; ( cd usr/sbin ; ln -sf ssmtp sendmail ) ; ( cd usr/lib ; ln -sf ../sbin/ssmtp sendmail )
+EOSCRIPT
+
+# Build the package
+cd "$PKG"
+makepkg -l y -c n "$REPOS/$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
index cd679cac6e283c706b0e4de00427750140fcdb7b..2d02ef33b04668dd0461765d18f419fc208a1703 100644 (file)
@@ -78,7 +78,7 @@ mkdir -p "$REPOS" || exit $ERROR_MKDIR
 mkdir -p "$PKG_WORK" || exit $ERROR_MKDIR
 
 # Dowload source if necessary
-SRC="$SRC_NAME"_"VERSION.orig.tar.gz"
+SRC="$SRC_NAME"_"$VERSION.orig.tar.gz"
 URL="http://ftp.de.debian.org/debian/pool/main/s/ssmtp/$SRC"
 
 if [ ! -s "$SRC_DIR/$SRC" ] || ! gunzip -t "$SRC_DIR/$SRC" 2> /dev/null; then
diff --git a/media/video/kino/Manifest b/media/video/kino/Manifest
new file mode 100644 (file)
index 0000000..e4b3dbc
--- /dev/null
@@ -0,0 +1,4 @@
+DIST kino-1.3.2.tar.gz 11064107 MD5 c534c666ed0312c75c877eb1580b985c RMD160 188323a1a8c4faa6c0cb0937fa161e8c4d61d964 SHA1 c59a3967432a450cb278601c961da1c946c72cfa SHA256 5d830fb0e32340f383d5ca9c503032c8df3ffa5c653c4d83f3f74eafea0b0532 SHA512 ebf45d2021f6a7d88da4345b349a1461398fb81d5d3c876fb22bdfadcb933a5a3c27ab5c094e9d37a2ab414486d5c3357fbe223f31280b0a322d6b1bec3640ee
+MKBUILD kino.mkbuild 3077 MD5 07d61ab018d07f7c4e8916ca1770dbbd RMD160 e080b8a444fc0c7e7885b3e6be6ae7e05f49ad38 SHA1 6bb9920e3c36cdaa8a2a229e619fc8eacf628fb2 SHA256 3ed6ec4aad8f4ee7786238f5d185ab67a8b629935e14c43f4a246912571307e3 SHA512 26d9a89599ac2651c6af321c41749165901a0577e03ef9f847e85279a24ecee8e9072c547cdb860d43d97c46320b9183ff11ae3cfcc4485c86a0ca08fdf1cbba
+SLACK-REQUIRED slack-required 155 MD5 8a9da8ce7947f8616643532ceca9afd3 RMD160 a8d6147ebcbf9a0065aff5d7f04a654ad55c78f7 SHA1 8fdae6caa300902a52beb8f8e793237808add725 SHA256 d394ef53175a1a0609a1e0dda7894173a708281380f5460ef0ed87c48c1ccd62 SHA512 7c9c2ccd7005321f09eade2618571432337230c4327b75bb9da026077262e8ff1cff39b5d717287f5e1202592794498f5e75c9409ac2d52ba759aa13f0a0e146
+SLACKBUILD kino.SlackBuild 7885 MD5 f851a505b69ef095ce47bec18514daee RMD160 4cc2f1bd946229a002774628c7f2617cc0dc3635 SHA1 e595dec6c0aac94a037408c9e1e59bf0e613b047 SHA256 d016e551503b9a9f7415f547913be8c1caf31c2a1b4287f872e1c27c99dd5e89 SHA512 6655b545b35f5c15a362b59bc28bde18525d02000827ac89ac1e119bb275071a089687efa3acc86e1e545e02404581adba41749b9b8e05a636588340cf722085
index 495bc4d85c433ec7db32df44cddfc841e07f98f5..efb336797a4bec4a7862c4276eeb9a7d490f796c 100755 (executable)
@@ -15,8 +15,8 @@
 #  59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
 #
 # slackbuild for kino, by Silvio Rhatto
-# requires: libsamplerate libraw1394 libavc1394 libdv libiec61883 libquicktime 
-# tested: kino-1.3.0
+# requires:  
+# tested: kino-1.3.2
 #
 
 # Look for slackbuildrc
@@ -47,9 +47,9 @@ NUMJOBS=${NUMJOBS:=""}
 LIBDIR="$PREFIX/lib"
 
 if [ "$ARCH" = "i386" ]; then
-  SLKCFLAGS="-O2 -march=i386 -mcpu=i686"
+  SLKCFLAGS="-O2 -march=i386 -mtune=i686"
 elif [ "$ARCH" = "i486" ]; then
-  SLKCFLAGS="-O2 -march=i486 -mcpu=i686"
+  SLKCFLAGS="-O2 -march=i486 -mtune=i686"
 elif [ "$ARCH" = "i686" ]; then
   SLKCFLAGS="-O2 -march=i686"
 elif [ "$ARCH" = "s390" ]; then
@@ -65,6 +65,7 @@ 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
@@ -84,6 +85,63 @@ 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_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
@@ -91,10 +149,11 @@ PKG_SRC="$PWD/`ls -l | awk '/^d/ { print $NF }'`"
 cd "$PKG_SRC"
 
 # Patch source
-patches="
+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
@@ -103,15 +162,7 @@ for patch in $patches; do
     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
-  fi
-done
-
-if echo [[PATCH URLS]] | grep -q -v "PATCH URLS"; then
-  for patch_url in [[PATCH URLS]]; do
-    patch="`basename $patch_url`"
-    if [ ! -s "$SRC_DIR/$patch" ]; then
-      wget "$patch_url" -O "$SRC_DIR/$patch" || exit $ERROR_WGET
-    fi
+  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
@@ -119,8 +170,8 @@ if echo [[PATCH URLS]] | grep -q -v "PATCH URLS"; then
     else
       patch -Np1 < "$SRC_DIR/$patch" || exit $ERROR_PATCH
     fi
-  done
-fi
+  fi
+done
 
 # Configure
 CFLAGS="$SLKCFLAGS" \
index 64b2438fcca6d6cef2339e7c8cc7d44390cb9caf..3fc6c61a1d0681d640c28324745400f92c6930ff 100644 (file)
@@ -7,4 +7,3 @@ libavc1394
 libdv                          
 libiec61883                            
 libquicktime                           
-intltool