summaryrefslogtreecommitdiffstats
path: root/games/citra/citra.SlackBuild
diff options
context:
space:
mode:
Diffstat (limited to 'games/citra/citra.SlackBuild')
-rw-r--r--games/citra/citra.SlackBuild261
1 files changed, 261 insertions, 0 deletions
diff --git a/games/citra/citra.SlackBuild b/games/citra/citra.SlackBuild
new file mode 100644
index 0000000000..227158002e
--- /dev/null
+++ b/games/citra/citra.SlackBuild
@@ -0,0 +1,261 @@
+#!/bin/bash
+
+# Slackware build script for citra
+
+# Copyright 2022-2024 Nathaniel Russell <naterussell83@gmail.com>
+# 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)
+
+PRGNAM=citra
+PRGVER=${PRGVER:-"69e758d73852ccb38577dd93ff7ae0402f681e60"}
+VERSION=${VERSION:-0.2090}
+BOOST=${BOOST:-3c27c785ad0f8a742af02e620dc225673f3a12d8}
+CATCH=${CATCH:-3f0283de7a9c43200033da996ff9093be3ac84dc}
+CPPJWT=${CPPJWT:-e12ef06218596b52d9b5d6e1639484866a8e7067}
+CRYPTOPP=${CRYPTOPP:-af7d1050bf2287072edd629be133da458a3cf978}
+CRYPTOCMAKE=${CRYPTOCMAKE:-a99c80c26686e44eddf0432140ae397f3efbd0b3}
+CUBEB=${CUBEB:-799e775484b8fce7e986ee7a4f4b651fec2bca07}
+DDSKTX=${DDSKTX:-42dd8aa6ded90b1ec06091522774feff51e83fc5}
+DISCORDRPC=${DISCORDRPC:-20cc99aeffa08a4834f156b6ab49ed68618cf94a}
+DYNARMIC=${DYNARMIC:-30f1a3c6289075ef4af08f5ec502be2fc8627a0c}
+ENET=${ENET:-4f8e9bdc4ce6d1f61a6274b0e557065a38190952}
+EXTSOUNDTOUCH=${EXTSOUNDTOUCH:-2.3.2}
+FAAD2=${FAAD2:-09b3c850c606e7fedd06597223e54344e8d23c8c}
+FMTLIB=${FMTLIB:-2dd4fa8742fdac36468f8d8ea3e06e78215551f8}
+GOOGLETEST=${GOOGLETEST:-40412d85124f7c6f3d88454583c4633e5e10fc8c}
+GLSLANG=${GLSLANG:-1e4955adbcd9b3f5eaf2129e918ca057baed6520}
+HEADERS=${HEADERS:-3b3e28dbe6d033395ce2967fa8030825e7b89de7}
+INIH=${INIH:-5e1d9e2625842dddb3f9c086a50f22e4f45dfc2b}
+LIBARE=${LIBARE:-deec5f75ee1a8ccbe32c8780b1d17284fc87b0f1}
+LIBRESSL=${LIBRESSL:-d4fc7348a3fbe9c659a373e28a3b50f052f7c50a}
+LIBUSB=${LIBUSB:-54350bd83fbcc9555abc57988d6fd73f3b9e9ff8}
+LIBYUV=${LIBYUV:-6900494d90ae095d44405cd4cc3f346971fa69c9}
+LODEPNG=${LODEPNG:-18964554bc769255401942e0e6dfd09f2fab2093}
+NIHSTRO=${NIHSTRO:-fd69de1a1b960ec296cc67d32257b0f9e2d89ac6}
+OAKNUT=${OAKNUT:-6b1d57ea7ed4882d32a91eeaa6557b0ecb4da152}
+OPENAL=${OPENAL:-d9fed51aa6391debc31dbbca550f055c980afe70}
+SANITIZERSCMAKE=${SANITIZERSCMAKE:-aab6948fa863bc1cbe5d0850bc46b9ef02ed4c1a}
+SDL2=${SDL2:-ac13ca9ab691e13e8eebe9684740ddcb0d716203}
+SIRIT=${SIRIT:-4ab79a8c023aa63caaa93848b09b9fe8b183b1a9}
+SPIRV=${SPIRV:-c214f6f2d1a7253bb0e9f195c2dc5b0659dc99ef}
+TEAKRA=${TEAKRA:-01db7cdd00aabcce559a8dddce8798dabb71949b}
+VULHEADER=${VULHEADER:-217e93c664ec6704ec2d8c36fa116c1a4a1e2d40}
+VULMEM=${VULMEM:-0e89587db3ebee4d463f191bd296374c5fafc8ea}
+XBYAK=${XBYAK:-a1ac3750f9a639b5a6c6d6c7da4259b8d6790989}
+ZSTD=${ZSTD:-63779c798237346c2b245c546c40b72a5a5913fe}
+BUILD=${BUILD:-1}
+TAG=${TAG:-_SBo}
+PKGTYPE=${PKGTYPE:-tgz}
+
+if [ -z "$ARCH" ]; then
+ case "$( uname -m )" in
+ i?86) ARCH=i586 ;;
+ arm*) ARCH=arm ;;
+ *) ARCH=$( uname -m ) ;;
+ esac
+fi
+
+TMP=${TMP:-/tmp/SBo}
+PKG=$TMP/package-$PRGNAM
+OUTPUT=${OUTPUT:-/tmp}
+DEPS=$TMP/$PRGNAM-$PRGVER/externals
+
+if [ ! -z "${PRINT_PACKAGE_NAME}" ]; then
+ echo "$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.$PKGTYPE"
+ exit 0
+fi
+
+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 $PRGNAM-$PRGVER
+tar xvf $CWD/$PRGNAM-$PRGVER.tar.?z
+
+# citra has quite a few external dependencies, we need to extract them to the correct location.
+tar xvf $CWD/ext-boost-$BOOST.tar.gz -C \
+ $DEPS/boost --strip-components 1
+tar xvf $CWD/Catch2-$CATCH.tar.gz -C \
+ $DEPS/catch2 --strip-components 1
+tar xvf $CWD/cpp-jwt-$CPPJWT.tar.gz -C \
+ $DEPS/cpp-jwt --strip-components 1
+tar xvf $CWD/cryptopp-$CRYPTOPP.tar.gz -C \
+ $DEPS/cryptopp --strip-components 1
+tar xvf $CWD/cryptopp-cmake-$CRYPTOCMAKE.tar.gz -C \
+ $DEPS/cryptopp-cmake --strip-components 1
+tar xvf $CWD/cubeb-$CUBEB.tar.gz -C \
+ $DEPS/cubeb --strip-components 1
+tar xvf $CWD/googletest-$GOOGLETEST.tar.gz -C \
+ $DEPS/cubeb/googletest --strip-components 1
+tar xvf $CWD/discord-rpc-$DISCORDRPC.tar.gz -C \
+ $DEPS/discord-rpc --strip-components 1
+tar xvf $CWD/dds-ktx-$DDSKTX.tar.gz -C \
+ $DEPS/dds-ktx --strip-components 1
+tar xvf $CWD/dynarmic-$DYNARMIC.tar.gz -C \
+ $DEPS/dynarmic --strip-components 1
+tar xvf $CWD/enet-$ENET.tar.gz -C \
+ $DEPS/enet --strip-components 1
+tar xvf $CWD/soundtouch-$EXTSOUNDTOUCH.tar.gz -C \
+ $DEPS/soundtouch --strip-components 1
+tar xvf $CWD/fmt-$FMTLIB.tar.gz -C \
+ $DEPS/fmt --strip-components 1
+tar xvf $CWD/inih-$INIH.tar.gz -C \
+ $DEPS/inih/inih --strip-components 1
+tar xvf $CWD/ext-libressl-portable-$LIBRESSL.tar.gz -C \
+ $DEPS/libressl --strip-components 1
+tar xvf $CWD/libusb-$LIBUSB.tar.gz -C \
+ $DEPS/libusb/libusb --strip-components 1
+tar xvf $CWD/libyuv-$LIBYUV.tar.gz -C \
+ $DEPS/libyuv --strip-components 1
+tar xvf $CWD/lodepng-$LODEPNG.tar.gz -C \
+ $DEPS/lodepng/lodepng --strip-components 1
+tar xvf $CWD/nihstro-$NIHSTRO.tar.gz -C \
+ $DEPS/nihstro --strip-components 1
+tar xvf $CWD/openal-soft-$OPENAL.tar.gz -C \
+ $DEPS/openal-soft --strip-components 1
+tar xvf $CWD/sanitizers-cmake-$SANITIZERSCMAKE.tar.gz -C \
+ $DEPS/cubeb/cmake/sanitizers-cmake --strip-components 1
+tar xvf $CWD/SDL-$SDL2.tar.gz -C \
+ $DEPS/sdl2/SDL --strip-components 1
+tar xvf $CWD/teakra-$TEAKRA.tar.gz -C \
+ $DEPS/teakra --strip-components 1
+tar xvf $CWD/xbyak-$XBYAK.tar.gz -C \
+ $DEPS/xbyak --strip-components 1
+tar xvf $CWD/zstd-$ZSTD.tar.gz -C \
+ $DEPS/zstd --strip-components 1
+tar xvf $CWD/faad2-$FAAD2.tar.gz -C \
+ $DEPS/faad2/faad2 --strip-components 1
+tar xvf $CWD/glslang-$GLSLANG.tar.gz -C \
+ $DEPS/glslang --strip-components 1
+tar xvf $CWD/ext-library-headers-$HEADERS.tar.gz -C \
+ $DEPS/library-headers --strip-components 1
+tar xvf $CWD/libadrenotools-$LIBARE.tar.gz -C \
+ $DEPS/libadrenotools --strip-components 1
+tar xvf $CWD/oaknut-$OAKNUT.tar.gz -C \
+ $DEPS/oaknut --strip-components 1
+tar xvf $CWD/sirit-$SIRIT.tar.gz -C \
+ $DEPS/sirit --strip-components 1
+tar xvf $CWD/Vulkan-Headers-$VULHEADER.tar.gz -C \
+ $DEPS/vulkan-headers --strip-components 1
+tar xvf $CWD/VulkanMemoryAllocator-$VULMEM.tar.gz -C \
+ $DEPS/vma --strip-components 1
+tar xvf $CWD/SPIRV-Headers-$SPIRV.tar.gz -C \
+ $DEPS/sirit/externals/SPIRV-Headers --strip-components 1
+
+# citra checks for external components by checking for their .git files.
+# Since these are not included when we downloaded the commit tarballs, we'll create them.
+echo "gitdir: ../../.git/modules/boost" > $DEPS/boost/.git
+echo "gitdir: ../../.git/modules/catch2" > $DEPS/catch2/.git
+echo "gitdir: ../../.git/modules/cpp-jwt" > $DEPS/cpp-jwt/.git
+echo "gitdir: ../../.git/modules/cryptopp" > $DEPS/cryptopp/.git
+echo "gitdir: ../../.git/modules/cryptopp-cmake" > $DEPS/cryptopp-cmake/.git
+echo "gitdir: ../../.git/modules/cubeb" > $DEPS/cubeb/.git
+echo "gitdir: ../../.git/modules/discord-rpc" > $DEPS/discord-rpc/.git
+echo "gitdir: ../../.git/modules/dds-ktx" > $DEPS/dds-ktx/.git
+echo "gitdir: ../../.git/modules/dynarmic" > $DEPS/dynarmic/.git
+echo "gitdir: ../../.git/modules/enet" > $DEPS/enet/.git
+echo "gitdir: ../../.git/modules/soundtouch" > $DEPS/soundtouch/.git
+echo "gitdir: ../../.git/modules/fmt" > $DEPS/fmt/.git
+echo "gitdir: ../../../.git/modules/inih" > $DEPS/inih/inih/.git
+echo "gitdir: ../../.git/modules/libressl" > $DEPS/libressl/.git
+echo "gitdir: ../../../.git/modules/libusb" > $DEPS/libusb/libusb/.git
+echo "gitdir: ../../.git/modules/libyuv" > $DEPS/libyuv/.git
+echo "gitdir: ../../../.git/modules/lodepng" > $DEPS/lodepng/lodepng/.git
+echo "gitdir: ../../.git/modules/nihstro" > $DEPS/nihstro/.git
+echo "gitdir: ../../.git/modules/openal-soft" > $DEPS/openal-soft/.git
+echo "gitdir: ../../.git/modules/sdl2/SDL" > $DEPS/sdl2/SDL/.git
+echo "gitdir: ../../.git/modules/teakra" > $DEPS/teakra/.git
+echo "gitdir: ../../.git/modules/xbyak" > $DEPS/xbyak/.git
+echo "gitdir: ../../.git/modules/zstd" > $DEPS/zstd/.git
+echo "gitdir: ../../.git/modules/faad2" > $DEPS/faad2/faad2/.git
+echo "gitdir: ../../.git/modules/glslang" > $DEPS/glslang/.git
+echo "gitdir: ../../.git/modules/library-headers" > $DEPS/library-headers/.git
+echo "gitdir: ../../.git/modules/libadrenotools" > $DEPS/libadrenotools/.git
+echo "gitdir: ../../.git/modules/oaknut" > $DEPS/oaknut/.git
+echo "gitdir: ../../.git/modules/sirit" > $DEPS/sirit/.git
+echo "gitdir: ../../.git/modules/sirit/externals/SPIRV-Headers" > $DEPS/sirit/externals/SPIRV-Headers/.git
+echo "gitdir: ../../.git/modules/vulkan-headers" > $DEPS/vulkan-headers/.git
+echo "gitdir: ../../.git/modules/vma" > $DEPS/vma/.git
+
+cd $PRGNAM-$PRGVER
+sed -i 's|DEPENDS "${GIT_DIR}/index" "${OpenAL_SOURCE_DIR}/version.cmake"|DEPENDS "${OpenAL_SOURCE_DIR}/version.cmake"|g' externals/openal-soft/CMakeLists.txt
+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 {} \;
+
+mkdir -p build
+cd build
+ cmake \
+ -DCMAKE_C_FLAGS:STRING="$SLKCFLAGS" \
+ -DCMAKE_CXX_FLAGS:STRING="$SLKCFLAGS" \
+ -DCMAKE_INSTALL_PREFIX=/usr \
+ -DLIB_SUFFIX=${LIBDIRSUFFIX} \
+ -DMAN_INSTALL_DIR=/usr/man \
+ -DCMAKE_BUILD_TYPE=Release ..
+ make
+ make install/strip DESTDIR=$PKG
+cd ..
+
+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
+
+mv $PKG/usr/share/man $PKG/usr
+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
+
+# Install hicolor
+for size in $(find /usr/share/icons/hicolor -type d -mindepth 1 -maxdepth 1 -exec basename {} \;); do
+ if [ -d assets/unix-icons/hicolor/${size} ]; then
+ cp -a assets/unix-icons/hicolor/${size} $PKG/usr/share/icons/hicolor/${size}
+ fi
+done
+
+mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION
+cp -a \
+ CONTRIBUTING* README* license.txt \
+ $PKG/usr/doc/$PRGNAM-$VERSION
+cat $CWD/qt-config.ini > $PKG/usr/doc/$PRGNAM-$VERSION/qt-config.ini.sample
+cat $CWD/$PRGNAM.SlackBuild > $PKG/usr/doc/$PRGNAM-$VERSION/$PRGNAM.SlackBuild
+
+mkdir -p $PKG/install
+cat $CWD/slack-desc > $PKG/install/slack-desc
+cat $CWD/doinst.sh > $PKG/install/doinst.sh
+
+cd $PKG
+/sbin/makepkg -l y -c n $OUTPUT/$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.$PKGTYPE