slackware-current/source/d/rust/rust.SlackBuild

285 lines
9.2 KiB
Text
Raw Normal View History

#!/bin/bash
# Copyright 2017 Andrew Clemons, Wellington, New Zealand
Mon Mar 15 19:37:28 UTC 2021 a/kernel-firmware-20210315_3568f96-noarch-1.txz: Upgraded. ap/sudo-1.9.6-x86_64-1.txz: Upgraded. d/cmake-3.19.7-x86_64-1.txz: Upgraded. d/python-setuptools-54.1.2-x86_64-1.txz: Upgraded. d/rust-1.50.0-x86_64-1.txz: Upgraded. l/libcap-2.49-x86_64-1.txz: Upgraded. l/python-urllib3-1.26.4-x86_64-1.txz: Upgraded. l/qt5-5.15.2-x86_64-6.txz: Rebuilt. Rebuilt with -proprietary-codecs and -webengine-proprietary-codecs. When combined with -webengine-ffmpeg (use system ffmpeg), this doesn't actually build any proprietary codecs, but allows them to be used if they happen to be built into the system ffmpeg. Thanks to alienBOB. xap/mozilla-firefox-86.0.1-x86_64-1.txz: Upgraded. When we first moved Slackware to the Firefox ESR channel, the motivation was to keep Firefox secure while delaying a requirement for Rust at build time. Of course, eventually that ESR version reached EOL and we had to introduce Rust into Slackware 14.2 in order to continue providing updates. Eventually that also ran into roadblocks as Firefox required first newer C/C++ compilers, and then finally a newer libstdc++. To continue, we'd have had to bump GCC to a much newer version, making other maintenance difficult or impossible. At this point, the latest Firefox has no additional dependencies beyond those of the ESR version, and it's unlikely that it will be any more difficult to keep it maintained. I think we all want the Slackware 15.0 release to be as good as possible, and most users will be better served if we resume following the latest desktop releases. Thanks to LuckyCyborg who can always be counted on to give me a friendly kick in the rear end. :-) Thanks also to ponce for the updated gkrust patch.
2021-03-15 20:37:28 +01:00
# Copyright 2017, 2018, 2019, 2020, 2021 Patrick J. Volkerding, Sebeka, Minnesota, USA
# Copyright 2017 Stuart Winter
# All rights reserved.
#
# Redistribution and use of this script, with or without modification, is
# permitted provided that the following conditions are met:
#
# 1. Redistributions of this script must retain the above copyright
# notice, this list of conditions and the following disclaimer.
#
# THIS SOFTWARE IS PROVIDED BY THE AUTHOR "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 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.
cd $(dirname $0) ; CWD=$(pwd)
PKGNAM=rust
SRCNAM="${PKGNAM}c"
Fri Mar 26 03:07:35 UTC 2021 a/btrfs-progs-5.11.1-x86_64-1.txz: Upgraded. a/dialog-1.3_20210324-x86_64-1.txz: Upgraded. a/kernel-generic-5.10.26-x86_64-1.txz: Upgraded. a/kernel-huge-5.10.26-x86_64-1.txz: Upgraded. a/kernel-modules-5.10.26-x86_64-1.txz: Upgraded. a/openssl-solibs-1.1.1k-x86_64-1.txz: Upgraded. d/kernel-headers-5.10.26-x86-1.txz: Upgraded. d/rust-1.51.0-x86_64-1.txz: Upgraded. e/emacs-27.2-x86_64-1.txz: Upgraded. k/kernel-source-5.10.26-noarch-1.txz: Upgraded. -ADI_AXI_ADC m AD9467 m -> n FONT_TER16x32 n -> y n/openssl-1.1.1k-x86_64-1.txz: Upgraded. This update fixes security issues: Fixed a problem with verifying a certificate chain when using the X509_V_FLAG_X509_STRICT flag. Fixed an issue where an OpenSSL TLS server may crash if sent a maliciously crafted renegotiation ClientHello message from a client. For more information, see: https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2021-3450 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2021-3449 (* Security fix *) n/samba-4.14.2-x86_64-1.txz: Upgraded. This is a security release in order to address the following defects: Heap corruption via crafted DN strings. Out of bounds read in AD DC LDAP server. For more information, see: https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2020-27840 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2021-20277 (* Security fix *) x/mesa-21.0.1-x86_64-1.txz: Upgraded. isolinux/initrd.img: Rebuilt. kernels/*: Upgraded. testing/packages/linux-5.11.x/kernel-generic-5.11.10-x86_64-1.txz: Upgraded. testing/packages/linux-5.11.x/kernel-headers-5.11.10-x86-1.txz: Upgraded. testing/packages/linux-5.11.x/kernel-huge-5.11.10-x86_64-1.txz: Upgraded. testing/packages/linux-5.11.x/kernel-modules-5.11.10-x86_64-1.txz: Upgraded. testing/packages/linux-5.11.x/kernel-source-5.11.10-noarch-1.txz: Upgraded. usb-and-pxe-installers/usbboot.img: Rebuilt.
2021-03-26 04:07:35 +01:00
VERSION=${VERSION:-1.51.0}
BUILD=${BUILD:-1}
# Set this to YES to build with the system LLVM, or NO to use the bundled LLVM.
# YES is probably better (when it works...)
SYSTEM_LLVM=${SYSTEM_LLVM:-YES}
# Bootstrap variables (might not be kept updated for latest Rust):
Fri Mar 26 03:07:35 UTC 2021 a/btrfs-progs-5.11.1-x86_64-1.txz: Upgraded. a/dialog-1.3_20210324-x86_64-1.txz: Upgraded. a/kernel-generic-5.10.26-x86_64-1.txz: Upgraded. a/kernel-huge-5.10.26-x86_64-1.txz: Upgraded. a/kernel-modules-5.10.26-x86_64-1.txz: Upgraded. a/openssl-solibs-1.1.1k-x86_64-1.txz: Upgraded. d/kernel-headers-5.10.26-x86-1.txz: Upgraded. d/rust-1.51.0-x86_64-1.txz: Upgraded. e/emacs-27.2-x86_64-1.txz: Upgraded. k/kernel-source-5.10.26-noarch-1.txz: Upgraded. -ADI_AXI_ADC m AD9467 m -> n FONT_TER16x32 n -> y n/openssl-1.1.1k-x86_64-1.txz: Upgraded. This update fixes security issues: Fixed a problem with verifying a certificate chain when using the X509_V_FLAG_X509_STRICT flag. Fixed an issue where an OpenSSL TLS server may crash if sent a maliciously crafted renegotiation ClientHello message from a client. For more information, see: https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2021-3450 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2021-3449 (* Security fix *) n/samba-4.14.2-x86_64-1.txz: Upgraded. This is a security release in order to address the following defects: Heap corruption via crafted DN strings. Out of bounds read in AD DC LDAP server. For more information, see: https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2020-27840 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2021-20277 (* Security fix *) x/mesa-21.0.1-x86_64-1.txz: Upgraded. isolinux/initrd.img: Rebuilt. kernels/*: Upgraded. testing/packages/linux-5.11.x/kernel-generic-5.11.10-x86_64-1.txz: Upgraded. testing/packages/linux-5.11.x/kernel-headers-5.11.10-x86-1.txz: Upgraded. testing/packages/linux-5.11.x/kernel-huge-5.11.10-x86_64-1.txz: Upgraded. testing/packages/linux-5.11.x/kernel-modules-5.11.10-x86_64-1.txz: Upgraded. testing/packages/linux-5.11.x/kernel-source-5.11.10-noarch-1.txz: Upgraded. usb-and-pxe-installers/usbboot.img: Rebuilt.
2021-03-26 04:07:35 +01:00
RSTAGE0_VERSION=${RSTAGE0_VERSION:-1.50.0}
RSTAGE0_DIR=${RSTAGE0_DIR:-2021-02-11}
CSTAGE0_VERSION=${CSTAGE0_VERSION:-1.50.0}
CSTAGE0_DIR=${CSTAGE0_DIR:-$RSTAGE0_DIR}
# Automatically determine the architecture we're building on:
MARCH=$( uname -m )
if [ -z "$ARCH" ]; then
case "$MARCH" in
i?86) export ARCH=i686 ;;
armv7hl) export ARCH=$MARCH ;;
arm*) export ARCH=arm ;;
# Unless $ARCH is already set, use uname -m for all other archs:
*) export ARCH=$MARCH ;;
esac
fi
unset MARCH
# For compiling i686 under an x86_64 kernel:
if [ "$(uname -m)" = "x86_64" -a "$(file -L /usr/bin/gcc | grep 80386 | grep 32-bit)" != "" ]; then
ARCH=i686
fi
# If the variable PRINT_PACKAGE_NAME is set, then this script will report what
# the name of the created package would be, and then exit. This information
# could be useful to other scripts.
if [ ! -z "${PRINT_PACKAGE_NAME}" ]; then
echo "$PKGNAM-$VERSION-$ARCH-$BUILD.txz"
exit 0
fi
# If the bootstrap binaries are present, use those. Otherwise bootstrap from
# installed compiler.
if /bin/ls *-unknown-linux-gnu.tar.gz 1> /dev/null 2> /dev/null ; then
LOCAL_BOOTSTRAP=no
else
LOCAL_BOOTSTRAP=yes
fi
# https://forge.rust-lang.org/platform-support.html
# Bootstrapping ARCH:
if [ "$ARCH" = "i586" ]; then
if [ "$LOCAL_BOOTSTRAP" = "yes" ] ; then
if rustc -Vv | grep host | grep i586 > /dev/null ; then
BARCH="$ARCH"
else
BARCH="i686"
if case "$( uname -m )" in i586) true ;; *) false ;; esac ; then
echo "rust must be bootstrapped from an i686 machine"
exit 1
fi
fi
else
# i586 must be built on a i686 machine, since the bootstrap compiler is i686
BARCH="i686"
if case "$( uname -m )" in i586) true ;; *) false ;; esac ; then
echo "rust must be bootstrapped from an i686 machine"
exit 1
fi
fi
TARCH="$ARCH"
elif [ "$ARCH" = "armv7hl" ]; then
BARCH="armv7"
TARCH="$BARCH"
else
BARCH="$ARCH"
TARCH="$ARCH"
fi
# Bootstrapping ABI:
if [ "$ARCH" = "armv7hl" ]; then
BABI="gnueabihf"
else
BABI="gnu"
fi
TMP=${TMP:-/tmp}
OUTPUT=${OUTPUT:-/tmp}
PKG=$TMP/package-$PKGNAM
# Not needed, as the build will automatically use as many jobs as there are
Mon Mar 15 19:37:28 UTC 2021 a/kernel-firmware-20210315_3568f96-noarch-1.txz: Upgraded. ap/sudo-1.9.6-x86_64-1.txz: Upgraded. d/cmake-3.19.7-x86_64-1.txz: Upgraded. d/python-setuptools-54.1.2-x86_64-1.txz: Upgraded. d/rust-1.50.0-x86_64-1.txz: Upgraded. l/libcap-2.49-x86_64-1.txz: Upgraded. l/python-urllib3-1.26.4-x86_64-1.txz: Upgraded. l/qt5-5.15.2-x86_64-6.txz: Rebuilt. Rebuilt with -proprietary-codecs and -webengine-proprietary-codecs. When combined with -webengine-ffmpeg (use system ffmpeg), this doesn't actually build any proprietary codecs, but allows them to be used if they happen to be built into the system ffmpeg. Thanks to alienBOB. xap/mozilla-firefox-86.0.1-x86_64-1.txz: Upgraded. When we first moved Slackware to the Firefox ESR channel, the motivation was to keep Firefox secure while delaying a requirement for Rust at build time. Of course, eventually that ESR version reached EOL and we had to introduce Rust into Slackware 14.2 in order to continue providing updates. Eventually that also ran into roadblocks as Firefox required first newer C/C++ compilers, and then finally a newer libstdc++. To continue, we'd have had to bump GCC to a much newer version, making other maintenance difficult or impossible. At this point, the latest Firefox has no additional dependencies beyond those of the ESR version, and it's unlikely that it will be any more difficult to keep it maintained. I think we all want the Slackware 15.0 release to be as good as possible, and most users will be better served if we resume following the latest desktop releases. Thanks to LuckyCyborg who can always be counted on to give me a friendly kick in the rear end. :-) Thanks also to ponce for the updated gkrust patch.
2021-03-15 20:37:28 +01:00
# threads.
Fri Sep 21 18:51:07 UTC 2018 a/eudev-3.2.6-x86_64-1.txz: Upgraded. a/glibc-solibs-2.28-x86_64-2.txz: Upgraded. a/grub-2.02-x86_64-3.txz: Rebuilt. Patched to fix compatibility with recent xfsprogs. Thanks to Markus Wiesner. a/kernel-generic-4.14.71-x86_64-1.txz: Upgraded. a/kernel-huge-4.14.71-x86_64-1.txz: Upgraded. a/kernel-modules-4.14.71-x86_64-1.txz: Upgraded. ap/opus-tools-0.2-x86_64-1.txz: Upgraded. ap/sqlite-3.25.1-x86_64-1.txz: Upgraded. d/icecream-20180905_cdc6ff8-x86_64-1.txz: Upgraded. d/kernel-headers-4.14.71-x86-1.txz: Upgraded. d/llvm-7.0.0-x86_64-1.txz: Upgraded. Shared library .so-version bump. k/kernel-source-4.14.71-noarch-1.txz: Upgraded. l/ffmpeg-3.4.4-x86_64-2.txz: Rebuilt. Don't try to link with Samba since the latest version is not compatible. l/glibc-2.28-x86_64-2.txz: Upgraded. All packages have been patched where needed for glibc-2.28 and compile tested here. Thanks to nobodino for the help. l/glibc-i18n-2.28-x86_64-2.txz: Upgraded. l/glibc-profile-2.28-x86_64-2.txz: Upgraded. l/gst-plugins-base-1.14.3-x86_64-1.txz: Upgraded. l/gst-plugins-good-1.14.3-x86_64-1.txz: Upgraded. l/gst-plugins-libav-1.14.3-x86_64-1.txz: Upgraded. l/gstreamer-1.14.3-x86_64-1.txz: Upgraded. l/imagemagick-6.9.10_11-x86_64-1.txz: Upgraded. l/libopusenc-0.2-x86_64-1.txz: Added. l/librsvg-2.44.3-x86_64-1.txz: Upgraded. l/opus-1.3_rc2-x86_64-1.txz: Upgraded. l/opusfile-0.11-x86_64-1.txz: Upgraded. l/soprano-2.9.4-x86_64-3.txz: Rebuilt. Recompiled to drop virtuoso dependency. l/virtuoso-ose-6.1.8-x86_64-9.txz: Removed. Even KDE4 has migrated away from actually using this for anything. The last thing in Slackware that was dependent on it was Soprano, which has been recompiled to no longer use it. n/postfix-3.3.1-x86_64-2.txz: Rebuilt. Recompiled so that it quits whining about OpenSSL. Thanks to shastah. x/mesa-18.2.1-x86_64-1.txz: Upgraded. Compiled against llvm-7.0.0. x/xf86-video-vmware-13.3.0-x86_64-2.txz: Rebuilt. Recompiled against llvm-7.0.0. x/xterm-336-x86_64-1.txz: Upgraded. extra/pure-alsa-system/ffmpeg-3.4.4-x86_64-2_alsa.txz: Rebuilt. Don't try to link with Samba since the latest version is not compatible. extra/pure-alsa-system/gst-plugins-good-1.14.3-x86_64-1_alsa.txz: Upgraded. isolinux/initrd.img: Rebuilt. kernels/*: Upgraded. usb-and-pxe-installers/usbboot.img: Rebuilt.
2018-09-21 20:51:07 +02:00
#NUMJOBS=${NUMJOBS:-" -j$(expr $(nproc) + 1) "}
if [ "$ARCH" = "i586" ]; then
LIBDIRSUFFIX=""
elif [ "$ARCH" = "i686" ]; then
LIBDIRSUFFIX=""
elif [ "$ARCH" = "x86_64" ]; then
LIBDIRSUFFIX="64"
elif [ "$ARCH" = "armv7hl" ]; then
LIBDIRSUFFIX=""
else
LIBDIRSUFFIX=""
fi
rm -rf $PKG
mkdir -p $TMP $PKG $OUTPUT
cd $TMP
rm -rf $SRCNAM-$VERSION-src
tar xvf $CWD/$SRCNAM-$VERSION-src.tar.?z || exit 1
cd $SRCNAM-$VERSION-src || exit 1
# Link with -lffi in case of using system LLVM:
if [ "${SYSTEM_LLVM}" = "YES" ]; then
zcat $CWD/link_libffi.diff.gz | patch -p1 --verbose || exit 1
fi
if [ "$LOCAL_BOOTSTRAP" != "yes" ] ; then
# rust requires bootstrapping with the previous rust version.
# versions are defined in src/stage0.txt.
mkdir -p build/cache/$RSTAGE0_DIR
cp $CWD/$PKGNAM-std-$RSTAGE0_VERSION-$BARCH-unknown-linux-gnu.tar.?z \
$CWD/$SRCNAM-$RSTAGE0_VERSION-$BARCH-unknown-linux-gnu.tar.?z \
build/cache/$RSTAGE0_DIR
mkdir -p build/cache/$CSTAGE0_DIR
cp $CWD/cargo-$CSTAGE0_VERSION-$BARCH-unknown-linux-gnu.tar.?z build/cache/$CSTAGE0_DIR
fi
# Build configuration. We'll go ahead and build with rpath because it may be
# needed during the build, and then we'll strip the rpaths out of the
# binaries later.
cat << EOF > config.toml
[llvm]
ccache = "/usr/bin/ccache"
link-shared = true
[build]
build = "$BARCH-unknown-linux-$BABI"
host = ["$TARCH-unknown-linux-$BABI"]
target = ["$TARCH-unknown-linux-$BABI"]
submodules = false
vendor = true
extended = true
[install]
prefix = "/usr"
docdir = "doc/rust-$VERSION"
libdir = "lib$LIBDIRSUFFIX"
mandir = "man"
[rust]
codegen-units = 0
channel = "stable"
rpath = true
codegen-tests = false
ignore-git = true
EOF
if [ "${SYSTEM_LLVM}" = "YES" ]; then
cat << EOF >> config.toml
# Add this stuff to build with the system LLVM:
[target.i586-unknown-linux-gnu]
llvm-config = "/usr/bin/llvm-config"
[target.i686-unknown-linux-gnu]
llvm-config = "/usr/bin/llvm-config"
[target.x86_64-unknown-linux-gnu]
llvm-config = "/usr/bin/llvm-config"
[target.armv7-unknown-linux-gnueabihf]
llvm-config = "/usr/bin/llvm-config"
EOF
fi
if [ "$LOCAL_BOOTSTRAP" = "yes" ] ; then
sed -i "s|^\(extended = true\)$|\1\nrustc = \"/usr/bin/rustc\"\ncargo = \"/usr/bin/cargo\"|" config.toml
fi
chown -R root:root .
find -L . \
\( -perm 777 -o -perm 775 -o -perm 750 -o -perm 711 -o -perm 555 \
-o -perm 511 \) -exec chmod 755 {} \+ -o \
\( -perm 666 -o -perm 664 -o -perm 640 -o -perm 600 -o -perm 444 \
-o -perm 440 -o -perm 400 \) -exec chmod 644 {} \+
export PKG_CONFIG_ALLOW_CROSS=1
if [ "$BARCH" = "i586" ] ; then
# when bootstrapping from i586 (rust already installed), also build a i686
# rustlib:
sed -i 's/^target =.*$/target = ["i686-unknown-linux-gnu"]/' config.toml
elif [ "$BARCH" = "i686" ] ; then
if [ "$TARCH" = "i586" ] ; then
# this will cause some messages like:
# warning: redundant linker flag specified for library `m`
# but will keep the build from falling over when doing the stage1 compiler
# linking for the i586 compiler. seems the correct flags don't get passed
# through and we end up failures like:
# error: linking with `clang` failed: exit code: 1
# /tmp/SBo/rustc-1.20.0-src/build/i686-unknown-linux-gnu/stage1-rustc/i586-unknown-linux-gnu/release/deps/librustc_llvm-4ab259c9aed547db.so: undefined reference to `xxx`
export RUSTFLAGS="$RUSTFLAGS -C link-args=-lrt -ldl -lcurses -lpthread -lz -lm"
fi
fi
# Build and install:
python x.py dist || exit 1
DESTDIR=$PKG python x.py install || exit 1
# Eh, none of this is all that big. Might as well leave it around as a
# reference.
#rm -f $PKG/usr/lib$LIBDIRSUFFIX/rustlib/components
#rm -f $PKG/usr/lib$LIBDIRSUFFIX/rustlib/install.log
#rm -f $PKG/usr/lib$LIBDIRSUFFIX/rustlib/manifest-*
#rm -f $PKG/usr/lib$LIBDIRSUFFIX/rustlib/rust-installer-version
#rm -f $PKG/usr/lib$LIBDIRSUFFIX/rustlib/uninstall.sh
# Make sure the paths are correct, though:
sed -i "s,/tmp/package-rust/,/,g" $PKG/usr/lib$LIBDIRSUFFIX/rustlib/install.log $PKG/usr/lib$LIBDIRSUFFIX/rustlib/manifest-*
# And a little compression doesn't hurt either:
gzip -9 $PKG/usr/lib$LIBDIRSUFFIX/rustlib/manifest-*
# Correct permissions on shared libraries:
find $PKG/usr/lib$LIBDIRSUFFIX -name "*.so" -exec chmod 755 "{}" \+
# Evidently there are a lot of duplicated libraries in this tree, so let's
# try to save some space:
( cd $PKG/usr/lib${LIBDIRSUFFIX}/rustlib/*-linux-gnu/lib && for file in *.so ; do if cmp -s $file ../../../$file ; then ln -sf ../../../$file .; fi; done )
# Strip ELF objects:
find $PKG -print0 | xargs -0 file | grep -e "executable" -e "shared object" | grep ELF \
| cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null || true
# Remove any compiled-in RPATHs:
find $PKG -print0 | xargs -0 file | grep -e "executable" -e "shared object" | grep ELF \
| cut -f 1 -d : | while read elfobject ; do
patchelf --remove-rpath $elfobject || exit 1
done
# Compress man pages:
find $PKG/usr/man -type f -exec gzip -9 {} \+
for i in $( find $PKG/usr/man -type l ) ; do ln -s $( readlink $i ).gz $i.gz ; rm $i ; done
# Add some documentation:
mkdir -p $PKG/usr/doc/$PKGNAM-$VERSION
cp -a *.md COPYRIGHT* COPYING* LICENSE* $PKG/usr/doc/$PKGNAM-$VERSION
# Include licenses from third party vendors:
mkdir $PKG/usr/doc/$PKGNAM-$VERSION/vendor
( cd vendor
tar cf - $(find . -maxdepth 2 | grep -e README -e LICENSE -e COPYING -e CHANGELOG -e PERFORMANCE -e UPGRADE ) | ( cd $PKG/usr/doc/$PKGNAM-$VERSION/vendor ; tar xf - )
)
mkdir -p $PKG/install
cat $CWD/slack-desc > $PKG/install/slack-desc
cd $PKG
/sbin/makepkg -l y -c n $OUTPUT/$PKGNAM-$VERSION-$ARCH-$BUILD.txz