summaryrefslogtreecommitdiff
path: root/development/cmake-202x/cmake-202x.SlackBuild
diff options
context:
space:
mode:
Diffstat (limited to 'development/cmake-202x/cmake-202x.SlackBuild')
-rw-r--r--development/cmake-202x/cmake-202x.SlackBuild115
1 files changed, 115 insertions, 0 deletions
diff --git a/development/cmake-202x/cmake-202x.SlackBuild b/development/cmake-202x/cmake-202x.SlackBuild
new file mode 100644
index 0000000000..a24fff5777
--- /dev/null
+++ b/development/cmake-202x/cmake-202x.SlackBuild
@@ -0,0 +1,115 @@
+#!/bin/sh
+
+############################################################
+# NOTE: Remove this from the repo when 15.0 ships! #
+# Also remove cmake-202x from REQUIRES in all .info files! #
+############################################################
+
+# Slackware build script for cmake-202x
+
+# Written by B. Watson (yalhcru@gmail.com)
+
+# Licensed under the WTFPL. See http://www.wtfpl.net/txt/copying/ for details.
+
+# This build exists because the cmake in Slackware 14.2 is too old,
+# and can't be upgraded. This installs cmake under /opt, where it
+# won't conflict with anything. README explains how to use it in your
+# SlackBuild.
+
+# cmake.manpages.tar.lz comes from Slackware, courtesy of Pat V. Since
+# it's from -current (therefore subject to change), I mirrored the
+# version I'm using on slackware.uk.
+
+PRGNAM=cmake-202x
+SRCNAM=cmake
+VERSION=${VERSION:-3.18.2}
+BUILD=${BUILD:-1}
+TAG=${TAG:-_SBo}
+
+if [ -z "$ARCH" ]; then
+ case "$( uname -m )" in
+ i?86) ARCH=i586 ;;
+ arm*) ARCH=arm ;;
+ *) ARCH=$( uname -m ) ;;
+ esac
+fi
+
+CWD=$(pwd)
+TMP=${TMP:-/tmp/SBo}
+PKG=$TMP/package-$PRGNAM
+OUTPUT=${OUTPUT:-/tmp}
+
+if [ "$ARCH" = "i586" ]; then
+ SLKCFLAGS="-O2 -march=i586 -mtune=i686"
+ LIBDIRSUFFIX=""
+elif [ "$ARCH" = "i686" ]; then
+ SLKCFLAGS="-O2 -march=i686 -mtune=i686"
+ LIBDIRSUFFIX=""
+elif [ "$ARCH" = "x86_64" ]; then
+ SLKCFLAGS="-O2 -fPIC"
+ LIBDIRSUFFIX="64"
+else
+ SLKCFLAGS="-O2"
+ LIBDIRSUFFIX=""
+fi
+
+set -e
+
+rm -rf $PKG
+mkdir -p $TMP $PKG $OUTPUT
+cd $TMP
+rm -rf $SRCNAM-$VERSION
+tar xvf $CWD/$SRCNAM-$VERSION.tar.gz
+cd $SRCNAM-$VERSION
+chown -R root:root .
+find -L . -perm /111 -a \! -perm 755 -a -exec chmod 755 {} \+ -o \
+ \! -perm /111 -a \! -perm 644 -a -exec chmod 644 {} \+
+
+PREFIX=${PREFIX:-/opt/$PRGNAM}
+PKGPREFIX=$PKG/$PREFIX
+
+# The --system-* and --no-system-* stuff is intended to use system
+# versions of libraries that ship with core Slackware, and bundled
+# (non-system) libs for everything that isn't in core, *even* if
+# it's available on SBo. This will prevent SBo upgrades from randomly
+# breaking things.
+
+CFLAGS="$SLKCFLAGS" \
+CXXFLAGS="$SLKCFLAGS" \
+./bootstrap \
+ --system-curl \
+ --system-expat \
+ --no-system-jsoncpp \
+ --system-zlib \
+ --system-bzip2 \
+ --system-liblzma \
+ --no-system-nghttp2 \
+ --no-system-zstd \
+ --system-libarchive \
+ --no-system-librhash \
+ --no-system-libuv \
+ --prefix=$PREFIX
+
+make
+make install/strip DESTDIR=$PKG
+
+# To avoid a dependency on Sphinx (which has *26 dependencies* of its own),
+# use Pat's prebuilt man pages.
+tar xvf $CWD/cmake.manpages.tar.lz
+mv usr/man $PKGPREFIX/man
+gzip -9 $PKGPREFIX/man/man?/*.?
+
+# Nothing in the doc dir but licenses. Move it to where users expect
+# to find it.
+mkdir -p $PKG/usr/doc
+mv $PKGPREFIX/doc/$SRCNAM-* $PKG/usr/doc/$PRGNAM-$VERSION
+rm -rf $PKGPREFIX/doc
+
+cat $CWD/$PRGNAM.SlackBuild > $PKG/usr/doc/$PRGNAM-$VERSION/$PRGNAM.SlackBuild
+cat $CWD/README_SBo.txt > $PKG/usr/doc/$PRGNAM-$VERSION/README_SBo.txt
+
+mkdir -p $PKG/install
+cat $CWD/slack-desc > $PKG/install/slack-desc
+
+cd $PKG
+/sbin/makepkg -l y -c n $OUTPUT/$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.${PKGTYPE:-tgz}