From 536c9463ecba71c4759f0c17c975a2d58b65542e Mon Sep 17 00:00:00 2001 From: Eric Hameleers Date: Thu, 11 Jul 2019 23:49:52 +0200 Subject: Deps: adding brotli and woff2 as new requirements for qt5-webkit --- deps/alldeps.SlackBuild | 2 + deps/brotli/.url | 1 + deps/brotli/brotli.SlackBuild | 132 ++++++++++++++++++++++++++++++++++++++++++ deps/brotli/slack-desc | 19 ++++++ deps/updates.SlackBuild | 2 + deps/woff2/.deps | 1 + deps/woff2/.url | 16 +++++ deps/woff2/slack-desc | 19 ++++++ deps/woff2/woff2.SlackBuild | 122 ++++++++++++++++++++++++++++++++++++++ 9 files changed, 314 insertions(+) create mode 100644 deps/brotli/.url create mode 100755 deps/brotli/brotli.SlackBuild create mode 100644 deps/brotli/slack-desc create mode 100644 deps/woff2/.deps create mode 100644 deps/woff2/.url create mode 100644 deps/woff2/slack-desc create mode 100755 deps/woff2/woff2.SlackBuild diff --git a/deps/alldeps.SlackBuild b/deps/alldeps.SlackBuild index bf662a6..e3040e0 100755 --- a/deps/alldeps.SlackBuild +++ b/deps/alldeps.SlackBuild @@ -22,6 +22,8 @@ ALLDEPS=" \ libxkbcommon \ wayland \ hyphen \ + brotli \ + woff2 \ qt5 \ qt5-webkit \ SDL_sound \ diff --git a/deps/brotli/.url b/deps/brotli/.url new file mode 100644 index 0000000..7b45d51 --- /dev/null +++ b/deps/brotli/.url @@ -0,0 +1 @@ +https://github.com/google/brotli/archive/v1.0.7.tar.gz diff --git a/deps/brotli/brotli.SlackBuild b/deps/brotli/brotli.SlackBuild new file mode 100755 index 0000000..fc9ac19 --- /dev/null +++ b/deps/brotli/brotli.SlackBuild @@ -0,0 +1,132 @@ +#!/bin/sh + +# Copyright 2019 Eric Hameleers, Eindhoven, NL +# Copyright 2019 Patrick J. Volkerding, Sebeka, MN, 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=brotli +VERSION=${VERSION:-1.0.7} +BUILD=${BUILD:-1} + +NUMJOBS=${NUMJOBS:-" -j$(nproc) "} + +TMP=${TMP:-/tmp} +PKG=$TMP/package-$PKGNAM + +# Automatically determine the architecture we're building on: +if [ -z "$ARCH" ]; then + case "$(uname -m)" in + i?86) ARCH=i586 ;; + arm*) readelf /usr/bin/file -A | egrep -q "Tag_CPU.*[4,5]" && ARCH=arm || ARCH=armv7hl ;; + # Unless $ARCH is already set, use uname -m for all other archs: + *) ARCH=$(uname -m) ;; + esac + export ARCH +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 [ "$ARCH" = "i586" ]; then + SLKCFLAGS="-O2 -march=i586 -mtune=i686" + SLKLDFLAGS=""; LIBDIRSUFFIX="" +elif [ "$ARCH" = "i686" ]; then + SLKCFLAGS="-O2 -march=i686 -mtune=i686" + SLKLDFLAGS=""; LIBDIRSUFFIX="" +elif [ "$ARCH" = "x86_64" ]; then + SLKCFLAGS="-O2 -fPIC" + SLKLDFLAGS="-L/usr/lib64"; LIBDIRSUFFIX="64" +elif [ "$ARCH" = "armv7hl" ]; then + SLKCFLAGS="-O2 -march=armv7-a -mfpu=vfpv3-d16" + SLKLDFLAGS=""; LIBDIRSUFFIX="" +else + SLKCFLAGS="-O2" + SLKLDFLAGS=""; LIBDIRSUFFIX="" +fi + +rm -rf $PKG +mkdir -p $TMP $PKG $OUTPUT +cd $TMP +rm -rf $PKGNAM-$VERSION +tar xf $CWD/$PKGNAM-$VERSION.tar.gz || exit 1 +cd $PKGNAM-$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 {} \; + +# First, python2 libraries: +python2 setup.py install --root=$PKG + +# Next, python3 libraries: +python3 setup.py install --root=$PKG + +# Finally, brotli itself: +mkdir -p build-${PKGNAM} +cd build-${PKGNAM} + cmake \ + -DCMAKE_C_FLAGS:STRING="$SLKCFLAGS" \ + -DCMAKE_CXX_FLAGS:STRING="$SLKCFLAGS" \ + -DCMAKE_C_FLAGS_RELEASE:STRING="$SLKCFLAGS" \ + -DCMAKE_CXX_FLAGS_RELEASE:STRING="$SLKCFLAGS" \ + -DCMAKE_BUILD_TYPE=Release \ + -DCMAKE_INSTALL_PREFIX=/usr \ + -DCMAKE_INSTALL_LIBDIR=/usr/lib${LIBDIRSUFFIX} \ + -DMAN_INSTALL_DIR=/usr/man \ + -DSYSCONF_INSTALL_DIR=/etc \ + -DLIB_SUFFIX=${LIBDIRSUFFIX} \ + -DBUILD_TESTING=NO \ + .. + make $NUMJOBS || make || exit 1 + make DESTDIR=$PKG install || exit 1 +cd - + +find $PKG | xargs file | grep -e "executable" -e "shared object" \ + | grep ELF | cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null + +mkdir -p $PKG/usr/doc/$PKGNAM-$VERSION +cp -a \ + BUILD CONTRIBUTING.md LICENSE README* WORKSPACE \ + $PKG/usr/doc/$PKGNAM-$VERSION +chown -R root:root $PKG/usr/doc + +# If there's a ChangeLog, installing at least part of the recent history +# is useful, but don't let it get totally out of control: +if [ -r ChangeLog ]; then + DOCSDIR=$(echo $PKG/usr/doc/${PKGNAM}-$VERSION) + cat ChangeLog | head -n 1000 > $DOCSDIR/ChangeLog + touch -r ChangeLog $DOCSDIR/ChangeLog +fi + +mkdir -p $PKG/install +cat $CWD/slack-desc > $PKG/install/slack-desc + +cd $PKG +/sbin/makepkg -l y -c n $TMP/$PKGNAM-$(echo $VERSION |tr - _)-$ARCH-$BUILD.txz + diff --git a/deps/brotli/slack-desc b/deps/brotli/slack-desc new file mode 100644 index 0000000..4d8a22f --- /dev/null +++ b/deps/brotli/slack-desc @@ -0,0 +1,19 @@ +# HOW TO EDIT THIS FILE: +# 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 make exactly 11 lines for the formatting to be correct. It's also +# customary to leave one space after the ':' except on otherwise blank lines. + + |-----handy-ruler------------------------------------------------------| +brotli: brotli (Brotli compression format) +brotli: +brotli: Brotli is a generic-purpose lossless compression algorithm that +brotli: compresses data using a combination of a modern variant of the LZ77 +brotli: algorithm, Huffman coding and 2nd order context modeling, with +brotli: a compression ratio comparable to the best currently available +brotli: general-purpose compression methods. +brotli: It is similar in speed with deflate but offers more dense compression. +brotli: +brotli: Homepage: https://github.com/google/brotli/ +brotli: diff --git a/deps/updates.SlackBuild b/deps/updates.SlackBuild index 671c1be..c6c675e 100755 --- a/deps/updates.SlackBuild +++ b/deps/updates.SlackBuild @@ -23,6 +23,8 @@ ALLDEPS=" \ libinput \ libxkbcommon \ wayland \ + brotli \ + woff2 \ hyphen \ qt5 \ qt5-webkit \ diff --git a/deps/woff2/.deps b/deps/woff2/.deps new file mode 100644 index 0000000..71867b8 --- /dev/null +++ b/deps/woff2/.deps @@ -0,0 +1 @@ +brotli diff --git a/deps/woff2/.url b/deps/woff2/.url new file mode 100644 index 0000000..c7e97d3 --- /dev/null +++ b/deps/woff2/.url @@ -0,0 +1,16 @@ +#!/bin/sh + +# Define variables: +PKGNAM=woff2 +MYDATE=$(date +%Y%m%d) +GITURI="https://github.com/google/${PKGNAM}.git" + +# Checkout source and create tarball: +rm -rf ${PKGNAM}temp +git clone ${GITURI} ${PKGNAM}temp +cd ${PKGNAM}temp + MYHASH=$(git rev-parse --short=7 HEAD) +cd - 1>/dev/null +mv ${PKGNAM}temp ${PKGNAM}-${MYHASH}_${MYDATE} +tar -Jcf ${PKGNAM}-${MYHASH}_${MYDATE}.tar.xz ${PKGNAM}-${MYHASH}_${MYDATE} +rm -rf ${PKGNAM}-${MYHASH}_${MYDATE} diff --git a/deps/woff2/slack-desc b/deps/woff2/slack-desc new file mode 100644 index 0000000..1d0ca07 --- /dev/null +++ b/deps/woff2/slack-desc @@ -0,0 +1,19 @@ +# HOW TO EDIT THIS FILE: +# 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 make exactly 11 lines for the formatting to be correct. It's also +# customary to leave one space after the ':' except on otherwise blank lines. + + |-----handy-ruler------------------------------------------------------| +woff2: woff2 (web font compression format) +woff2: +woff2: WOFF2 is the Web Open Font Format 2 reference implementation. +woff2: See also https://www.w3.org/TR/WOFF2/ +woff2: This tarball contains an embedded version of brotli (a lossless +woff2: compression algorithm) used to build woff2. +woff2: +woff2: +woff2: +woff2: Homepage: https://github.com/google/woff2 +woff2: diff --git a/deps/woff2/woff2.SlackBuild b/deps/woff2/woff2.SlackBuild new file mode 100755 index 0000000..6293b3f --- /dev/null +++ b/deps/woff2/woff2.SlackBuild @@ -0,0 +1,122 @@ +#!/bin/sh +# Copyright 2019 Patrick J. Volkerding, Sebeka, MN, USA +# Copyright 2019 Eric Hameleers, Eindhoven, NL +# All rights reserved. +# +# Permission to use, copy, modify, and distribute this software for +# any purpose with or without fee is hereby granted, provided that +# the above copyright notice and this permission notice appear in all +# copies. +# +# THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED 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 AUTHORS AND COPYRIGHT HOLDERS AND THEIR +# CONTRIBUTORS 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=woff2 +VERSION=${VERSION:-"a0d0ed7_20190630"} +BUILD=${BUILD:-1} + +NUMJOBS=${NUMJOBS:-" -j$(nproc) "} + +TMP=${TMP:-/tmp} +PKG=$TMP/package-$PKGNAM + +# Automatically determine the architecture we're building on: +if [ -z "$ARCH" ]; then + case "$(uname -m)" in + i?86) ARCH=i586 ;; + arm*) readelf /usr/bin/file -A | egrep -q "Tag_CPU.*[4,5]" && ARCH=arm || ARCH=armv7hl ;; + # Unless $ARCH is already set, use uname -m for all other archs: + *) ARCH=$(uname -m) ;; + esac + export ARCH +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 + +# Set CFLAGS/CXXFLAGS and LIBDIRSUFFIX: +if [ "$ARCH" = "i486" ]; then + SLKCFLAGS="-O2 -march=i486 -mtune=i686" + LIBDIRSUFFIX="" +elif [ "$ARCH" = "s390" ]; then + SLKCFLAGS="-O2" + LIBDIRSUFFIX="" +elif [ "$ARCH" = "x86_64" ]; then + SLKCFLAGS="-O2 -fPIC" + LIBDIRSUFFIX="64" +elif [ "$ARCH" = "arm" ]; then + SLKCFLAGS="-O2 -march=armv5te" + LIBDIRSUFFIX="" +else + SLKCFLAGS="-O2" + LIBDIRSUFFIX="" +fi + +case "$ARCH" in + arm*) TARGET=$ARCH-slackware-linux-gnueabi ;; + *) TARGET=$ARCH-slackware-linux ;; +esac + +rm -rf $PKG +mkdir -p $TMP $PKG +cd $TMP +rm -rf $PKGNAM-$VERSION +tar xvf $CWD/$PKGNAM-$VERSION.tar.xz || exit 1 +cd $PKGNAM-$VERSION || exit 1 + +# Make sure ownerships and permissions are sane: +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 {} \; + +# Build and install: +export CFLAGS="$SLKCFLAGS" +export CXXFLAGS="$SLKCFLAGS" +cmake \ + -G Ninja \ + -DCMAKE_INSTALL_PREFIX=/usr \ + -DCMAKE_INSTALL_LIBDIR=/usr/lib${LIBDIRSUFFIX} \ + . || exit 1 +ninja || exit 1 +DESTDIR=$PKG ninja install || exit 1 + +# Strip binaries: +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 + +# Add documentation: +mkdir -p $PKG/usr/doc/$PKGNAM-$VERSION +cp -a \ + CONTRIBUTING.md LICENSE README.md \ + $PKG/usr/doc/$PKGNAM-$VERSION + +# Add a description: +mkdir -p $PKG/install +cat $CWD/slack-desc > $PKG/install/slack-desc + +# Create the package: +cd $PKG +/sbin/makepkg -l y -c n $TMP/$PKGNAM-$VERSION-$ARCH-$BUILD.txz + -- cgit v1.2.3