mirror of
git://slackware.nl/current.git
synced 2025-02-06 20:46:02 +01:00
![Patrick J Volkerding](/assets/img/avatar_default.png)
patches/packages/linux-5.15.63/*: Upgraded. These updates fix various bugs and security issues. Be sure to upgrade your initrd after upgrading the kernel packages. If you use lilo to boot your machine, be sure lilo.conf points to the correct kernel and initrd and run lilo as root to update the bootloader. If you use elilo to boot your machine, you should run eliloconfig to copy the kernel and initrd to the EFI System Partition. For more information, see: Fixed in 5.15.39: https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-1974 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-1975 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-1734 Fixed in 5.15.40: https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-1943 Fixed in 5.15.41: https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-28893 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-32296 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-1012 Fixed in 5.15.42: https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-1652 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-1729 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-21499 Fixed in 5.15.44: https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-1789 Fixed in 5.15.45: https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-2873 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-1966 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-32250 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-2078 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-1852 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-1972 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-2503 Fixed in 5.15.46: https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-1184 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-1973 Fixed in 5.15.47: https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-34494 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-34495 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-32981 Fixed in 5.15.48: https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-21125 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-21166 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-21123 Fixed in 5.15.53: https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-2318 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-33743 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-33742 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-33741 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-33740 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-26365 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-33744 Fixed in 5.15.54: https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2021-33655 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-34918 Fixed in 5.15.56: https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-36123 Fixed in 5.15.57: https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-29900 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-29901 Fixed in 5.15.58: https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-21505 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-1462 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-36879 Fixed in 5.15.59: https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-36946 Fixed in 5.15.60: https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-26373 Fixed in 5.15.61: https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-2586 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-2585 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-1679 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-2588 (* Security fix *) patches/packages/vim-9.0.0270-x86_64-1_slack15.0.txz: Upgraded. We're just going to move to vim-9 instead of continuing to backport patches to the vim-8 branch. Most users will be better served by this. Fixed use after free and null pointer dereference. Thanks to marav for the heads-up. For more information, see: https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-2946 https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-2923 (* Security fix *) patches/packages/vim-gvim-9.0.0270-x86_64-1_slack15.0.txz: Upgraded.
241 lines
7.7 KiB
Bash
Executable file
241 lines
7.7 KiB
Bash
Executable file
#!/bin/bash
|
|
|
|
# Copyright 2008, 2009, 2010, 2013, 2016, 2018, 2019, 2020, 2021 Patrick J. Volkerding, Sebeka, Minnesota, USA
|
|
# 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=vim
|
|
VIMBRANCH=9.0
|
|
CTAGSVER=5.8
|
|
BUILD=${BUILD:-1_slack15.0}
|
|
|
|
# The possible settings for this are yes/no/dynamic.
|
|
PERLINTERP=${PERLINTERP:-dynamic}
|
|
|
|
if [ -r vim-${VIMBRANCH}*.tar.?z ]; then # if there's a source archive already, use the version number from it:
|
|
VERSION=$(echo vim-${VIMBRANCH}*.tar.?z | rev | cut -f 3- -d . | cut -f 1 -d - | rev)
|
|
else # need to fetch the latest source archive for this branch:
|
|
VERSION="$(wget -q -O - https://www.vim.org | grep "^${VIMBRANCH}" | head -n 1)"
|
|
( lftpget https://github.com/vim/vim/archive/v${VERSION}.tar.gz
|
|
gzip -d v${VERSION}.tar.gz
|
|
mv v${VERSION}.tar vim-${VERSION}.tar
|
|
plzip -9 -n 6 vim-${VERSION}.tar
|
|
if [ ! -r vim-${VERSION}.tar.lz ]; then
|
|
echo "ERROR: Something went wrong trying to fetch https://github.com/vim/vim/archive/v${VERSION}.tar.gz"
|
|
exit 1
|
|
fi
|
|
) || exit 1
|
|
fi
|
|
|
|
# Automatically determine the architecture we're building on:
|
|
if [ -z "$ARCH" ]; then
|
|
case "$( uname -m )" in
|
|
i?86) export ARCH=i586 ;;
|
|
arm*) export ARCH=arm ;;
|
|
# Unless $ARCH is already set, use uname -m for all other archs:
|
|
*) export ARCH=$( uname -m ) ;;
|
|
esac
|
|
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 dynamic support for Ruby works with this $ARCH, then allow it:
|
|
if [ "$ARCH" = "x86_64" ]; then
|
|
RUBYDYNAMIC="=dynamic"
|
|
fi
|
|
|
|
NUMJOBS=${NUMJOBS:-" -j$(expr $(nproc) + 1) "}
|
|
|
|
PYVER=$(python -V 2>&1 | cut -f 2 -d' ' | cut -f 1-2 -d.)
|
|
|
|
if [ "$ARCH" = "x86_64" ]; then
|
|
export SLKCFLAGS="-O2 -fPIC"
|
|
export LIBDIRSUFFIX="64"
|
|
else
|
|
export SLKCFLAGS="-O2"
|
|
export LIBDIRSUFFIX=""
|
|
fi
|
|
export SLKLDFLAGS="-L/usr/lib${LIBDIRSUFFIX}"
|
|
|
|
TMP=${TMP:-/tmp}
|
|
PKG=$TMP/package-vim
|
|
|
|
rm -rf $PKG
|
|
mkdir -p $TMP $PKG
|
|
|
|
# ctags was once a part of vim,
|
|
# but now we have to bundle it in
|
|
cd $TMP
|
|
rm -rf ctags-$CTAGSVER
|
|
tar xvf $CWD/ctags-$CTAGSVER.tar.?z || exit 1
|
|
cd ctags-$CTAGSVER || exit 1
|
|
chown -R root:root .
|
|
find . \
|
|
\( -perm 777 -o -perm 775 -o -perm 711 -o -perm 555 -o -perm 511 \) \
|
|
-exec chmod 755 {} \+ -o \
|
|
\( -perm 666 -o -perm 664 -o -perm 600 -o -perm 444 -o -perm 440 -o -perm 400 \) \
|
|
-exec chmod 644 {} \+
|
|
|
|
# patch to solve an issue introduced by glibc-2.34 from http://deb.debian.org/debian/pool/main/e/exuberant-ctags/exuberant-ctags_5.9~svn20110310-15.debian.tar.xz
|
|
zcat $CWD/ctags.use-conventional-unused-marker.patch.gz | patch -Esp1 --verbose || exit 1
|
|
|
|
CFLAGS="$SLKCFLAGS" LDFLAGS="$SLKLDFLAGS" \
|
|
./configure \
|
|
--prefix=/usr \
|
|
--build=$ARCH-slackware-linux
|
|
make $NUMJOBS || make || exit 1
|
|
mkdir -p $PKG/usr/bin
|
|
cat ctags > $PKG/usr/bin/ctags
|
|
chmod 755 $PKG/usr/bin/ctags
|
|
mkdir -p $PKG/usr/man/man1
|
|
cat ctags.1 | gzip -9c > $PKG/usr/man/man1/ctags.1.gz
|
|
mkdir -p $PKG/usr/doc/ctags-$CTAGSVER
|
|
cp -a \
|
|
COPYING* EXTENDING.html FAQ INSTALL INSTALL.oth NEWS README* \
|
|
$PKG/usr/doc/ctags-$CTAGSVER
|
|
chmod 644 $PKG/usr/doc/ctags-$CTAGSVER/*
|
|
|
|
cd $TMP
|
|
rm -rf vim-${VERSION}
|
|
tar xvf $CWD/vim-${VERSION}.tar.?z || exit 1
|
|
|
|
config_vim() {
|
|
CFLAGS="$SLKCFLAGS" \
|
|
./configure \
|
|
$* \
|
|
--prefix=/usr \
|
|
--with-python-config-dir=/usr/lib${LIBDIRSUFFIX}/python$PYVER/config \
|
|
--with-python3-config-dir=$(python3-config --configdir) \
|
|
--enable-perlinterp=$PERLINTERP \
|
|
--enable-pythoninterp=dynamic \
|
|
--enable-python3interp=dynamic \
|
|
--enable-rubyinterp${RUBYDYNAMIC} \
|
|
--enable-tclinterp=dynamic \
|
|
--disable-canberra \
|
|
--enable-multibyte \
|
|
--enable-cscope \
|
|
--with-features=huge \
|
|
--with-compiledby="<volkerdi@slackware.com>" \
|
|
--build=$ARCH-slackware-linux || exit 1
|
|
}
|
|
|
|
cd $TMP/vim-$VERSION || exit 1
|
|
|
|
chown -R root:root .
|
|
find . \
|
|
\( -perm 777 -o -perm 775 -o -perm 711 -o -perm 555 -o -perm 511 \) \
|
|
-exec chmod 755 {} \+ -o \
|
|
\( -perm 666 -o -perm 664 -o -perm 600 -o -perm 444 -o -perm 440 -o -perm 400 \) \
|
|
-exec chmod 644 {} \+
|
|
|
|
config_vim --without-x --disable-gui || exit 1
|
|
make $NUMJOBS || make || exit 1
|
|
make install DESTDIR=$PKG || exit 1
|
|
|
|
rsync -lprvt $PKG/usr/share/man/ $PKG/usr/man/
|
|
rm -r $PKG/usr/share/man
|
|
|
|
# Don't make backups in /var/spool/cron/*, which fixes "crontab -e":
|
|
zcat $CWD/vim.vimrc.diff.gz | patch -p1 --verbose || exit 1
|
|
|
|
cp -a runtime/vimrc_example.vim runtime/vimrc.new
|
|
|
|
# Add patched vimrc to the package:
|
|
cat runtime/vimrc.new > $PKG/usr/share/vim/vimrc.new
|
|
|
|
# Don't package gvim.desktop - it will be included in the vim-gvim package:
|
|
rm -f $PKG/usr/share/applications/gvim.desktop
|
|
|
|
# Move the vim.desktop into the docs directory. There's really not much use
|
|
# for this .desktop file. It's easy enough to just open a terminal and run
|
|
# vim in it without this.
|
|
mkdir -p $PKG/usr/doc/vim-$VERSION
|
|
mv $PKG/usr/share/applications/vim.desktop $PKG/usr/doc/vim-$VERSION
|
|
|
|
# Remove empty directory:
|
|
rmdir $PKG/usr/share/applications
|
|
|
|
# Fix manpage symlinks:
|
|
if [ -d $PKG/usr/man ]; then
|
|
( cd $PKG/usr/man
|
|
for manpagedir in $(find . -type d -name "man*") ; do
|
|
( cd $manpagedir
|
|
for eachpage in $( find . -type l -maxdepth 1) ; do
|
|
ln -s $( readlink $eachpage ).gz $eachpage.gz
|
|
rm $eachpage
|
|
done
|
|
gzip -9 *.?
|
|
)
|
|
done
|
|
)
|
|
fi
|
|
|
|
# Legacy binary links:
|
|
( cd $PKG/usr/bin ; rm -rf rview )
|
|
( cd $PKG/usr/bin ; ln -sf vim rview )
|
|
( cd $PKG/usr/bin ; rm -rf rvim )
|
|
( cd $PKG/usr/bin ; ln -sf vim rvim )
|
|
( cd $PKG/usr/bin ; rm -rf view )
|
|
( cd $PKG/usr/bin ; ln -sf vim view )
|
|
( cd $PKG/usr/bin ; rm -rf eview )
|
|
( cd $PKG/usr/bin ; ln -sf vim eview )
|
|
( cd $PKG/usr/bin ; rm -rf evim )
|
|
( cd $PKG/usr/bin ; ln -sf vim evim )
|
|
|
|
# These should not be shipped:
|
|
rm -f $PKG/usr/bin/{ex,vi}
|
|
|
|
mkdir -p $PKG/usr/doc/vim-$VERSION
|
|
cp -a README.txt $PKG/usr/doc/vim-$VERSION
|
|
find $PKG/usr/doc/vim-$VERSION -type f | xargs chmod 644
|
|
( cd $PKG/usr/doc/vim-$VERSION ; rm -rf doc )
|
|
( cd $PKG/usr/doc/vim-$VERSION ; ln -sf /usr/share/vim/vim$(echo $VIMBRANCH | tr -d .) doc )
|
|
|
|
mkdir -p $PKG/install
|
|
cat $CWD/slack-desc.vim > $PKG/install/slack-desc
|
|
cat << EOF > $PKG/install/doinst.sh
|
|
#!/bin/bash
|
|
config() {
|
|
NEW="\$1"
|
|
OLD="\$(dirname \$NEW)/\$(basename \$NEW .new)"
|
|
# 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...
|
|
}
|
|
config usr/share/vim/vimrc.new
|
|
EOF
|
|
|
|
find $PKG | xargs file | grep -e "executable" -e "shared object" | grep ELF \
|
|
| cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null
|
|
|
|
cd $PKG
|
|
/sbin/makepkg -l y -c n $TMP/vim-$VERSION-$ARCH-$BUILD.txz
|
|
|