aboutsummaryrefslogtreecommitdiff
path: root/media/libs/openexr
diff options
context:
space:
mode:
Diffstat (limited to 'media/libs/openexr')
-rw-r--r--media/libs/openexr/Manifest24
-rwxr-xr-xmedia/libs/openexr/openexr.SlackBuild95
2 files changed, 103 insertions, 16 deletions
diff --git a/media/libs/openexr/Manifest b/media/libs/openexr/Manifest
new file mode 100644
index 00000000..e8c88225
--- /dev/null
+++ b/media/libs/openexr/Manifest
@@ -0,0 +1,24 @@
+-----BEGIN PGP SIGNED MESSAGE-----
+Hash: SHA1
+
+DIST openexr-1.6.1.tar.gz 13632660 MD5 11951f164f9c872b183df75e66de145a RMD160 3670633be841628e9d4c11981661e9d94a9b2711 SHA1 b3650e6542f0e09daadb2d467425530bc8eec333 SHA256 c616906ab958de9c37bb86ca7547cfedbdfbad5e1ca2a4ab98983c9afa6a5950 SHA512 876a5140a1e443e4ba59f84c07fbdb475d7674c00dacf661769c77a275b54cd220c7999d47f96bfb421caf31ca8b65abb01531ac3467b6769ca1fbe92ad32bbe
+MKBUILD openexr.mkbuild 2972 MD5 a610f70fe1c3d16646f90b98d32a9d76 RMD160 2ec567339b13e4b9f3103f48386bc56e8ac781da SHA1 273239ad7dbe430f0fbb7278325c8532901baa8f SHA256 916b83a2758fec49bc2bf643c265c6decd7cc9dafe882948380427a455417a8f SHA512 20889b511c2cec12c996ac6408119b66c98a9143630230dbd684d21cc8d5f3173b50f694e370bdc7cec450b3587ed28c9ddd599f30f70e94027a2bd5912cbf2f
+SLACK-REQUIRED slack-required 79 MD5 8536769ab1d45563cc13d0c45f56f3a9 RMD160 92317a4feff72d01c6fd64e7ec376b2c4c77fe26 SHA1 736dbb7237f333ac0619a7544f8af27e55b8060f SHA256 837a9a41c24dee76ba47c502ed2fefe511a4a6ad6b3ed408a824385d13563f9b SHA512 b6bcc0ee5206cc8a37ed901b3464d35decfbfc6ecc7e698f4a53eebf1d1d70137d6da1dfd949f6068eb606d382d26452beb20b69507e8fe9d518364737f830a4
+SLACKBUILD openexr.SlackBuild 8281 MD5 86342a6dbd4225975cc84b3e979fbac3 RMD160 c392980559c58da98a4c0944fa30bd5f66b8d7a1 SHA1 921c8adff89b86fb8175c83f5465db3e74067dcc SHA256 2fceae05cd6eaf8be8f3b25582b2a36100f16b0817e0063901807278aa903f3e SHA512 c82329501f6f06cb8ececff0e578e48a6635652dd45f22f0cf89e1d494d44ee73a2d0c37b3195e86a6cfa479ef02563694a879b230471ffb1810eaa4bfcf8f50
+-----BEGIN PGP SIGNATURE-----
+Version: GnuPG v1.4.9 (GNU/Linux)
+
+iQIcBAEBAgAGBQJJ/f0iAAoJEEHL93ESzgeiGkwP/0882Pu5kxRbmausOA0bNCwU
+2/YJ9lsQbg17l7EUT1c0Hhjl1bGsaGM6aSw+yooATitMqj9Vu8lHJ2LXssS5gIZT
+iaHq3QbXcnhz3Ic8JAcZVuSJw/ZoEAcrQEzg/Xq+aePaPkt+yT4WlJvKP7leHF6d
+WPdlbxrMWrmCtlH4UD0i5NUMHtYMVx8DOdvEiuBK12P3qLwCzQ0V2HNrhKakv4Aw
+V/RGcGLrDUjd1CyDK8g6Q50r9J3yoYqw044fn6C9XhQ+MCWew+oUvwfbj9Gajqak
+IA/cY5QrBkAT9dCIKf1Y5q/dRxbnK9XIkumv1vizm1pAMXIjR/l1jcRgbqfbunZf
+YlgDkWqdbLPqpFE6P6FjSMTOv+sa/tR0olS8j7euPnPb+rEr75Jub+1LlAI/S3yl
+R7Rs+Tb7z/8hIVOU1SXBDMfxoofytXXEfhuQK2idkD55xamdmTMhaTUCAuvDqtc3
+lq2en85GyJdOzq99kkjJGaWCpExv/5NT4FylG0zQHgCT/WxiAaRKeqAPh/F7KLWK
+KRNdpjZTPzq/3FwDsGsUZ0VhGZE5V4pRO/NUyRxKdZP1mhSNMfo9i+b7wJeN1S3U
+ukGHKF6vnUmSRcogE5IvJi4+bTXvUFu3fMNTlK8nh66PzuBg+iITWNPFf17z12U9
+fuqeFU5pQHuGaSpumyfc
+=lOJh
+-----END PGP SIGNATURE-----
diff --git a/media/libs/openexr/openexr.SlackBuild b/media/libs/openexr/openexr.SlackBuild
index d5bde31e..9736a026 100755
--- a/media/libs/openexr/openexr.SlackBuild
+++ b/media/libs/openexr/openexr.SlackBuild
@@ -15,8 +15,9 @@
# 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
#
# slackbuild for openexr, by Silvio Rhatto
-# requires: ilmbase
+# requires:
# tested: openexr-1.6.1
+# model: generic.mkSlackBuild $Rev: 805 $
#
# Look for slackbuildrc
@@ -38,6 +39,7 @@ SRC_DIR=${SRC_DIR:=$CWD}/$PKG_NAME
TMP=${TMP:=/tmp}
PKG=${PKG:=$TMP/package-$PKG_NAME}
REPOS=${REPOS:=$TMP}
+SLACKBUILD_PATH=${SLACKBUILD_PATH:="media/libs/openexr"}
PREFIX=${PREFIX:=/usr}
PKG_WORK="$TMP/$SRC_NAME"
CONF_OPTIONS=${CONF_OPTIONS:="--with-docdir=/usr/doc/$PKG_NAME-$PKG_VERSION"}
@@ -47,9 +49,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 +67,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 +87,72 @@ 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
@@ -91,10 +160,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 +173,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 +181,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" \
@@ -183,7 +245,8 @@ fi
# Build the package
cd "$PKG"
-makepkg -l y -c n "$REPOS/$PKG_NAME-$PKG_VERSION-$ARCH-$BUILD.tgz" || exit $ERROR_MKPKG
+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