Dump
This commit is contained in:
parent
1ef93799d1
commit
2df9b96765
98 changed files with 30423 additions and 0 deletions
166
buildtools/appimage/build.sh
Executable file
166
buildtools/appimage/build.sh
Executable file
|
@ -0,0 +1,166 @@
|
|||
#!/bin/bash
|
||||
|
||||
set -eo >/dev/null
|
||||
|
||||
CURRENT_APPIMAGEKIT_RELEASE=9
|
||||
ARCH="$(uname -m)"
|
||||
|
||||
if [[ $# -lt 1 ]]; then
|
||||
echo "Usage: $0 <version>"
|
||||
exit 0
|
||||
fi
|
||||
|
||||
VERSION="$1"
|
||||
LOVEFILE="$2"
|
||||
USERNAME=$3
|
||||
TOKEN=$4
|
||||
|
||||
# https://github.com/love2d/love/releases/download/11.5/love-11.5-x86_64.AppImage
|
||||
# https://github.com/love2d/love/releases/download/11.4/love-11.4-x86_64.AppImage
|
||||
# https://github.com/love2d/love/releases/download/11.3/love-11.3-x86_64.AppImage
|
||||
# https://github.com/love2d/love/releases/download/11.2/love-11.2-x86_64.AppImage
|
||||
# https://github.com/love2d/love/releases/download/11.1/love-11.1-linux-x86_64.AppImage
|
||||
LOVE_AppImage_URL=https://github.com/love2d/love/releases/download/${VERSION}/love-${VERSION}-${ARCH}.AppImage
|
||||
if [ $VERSION == "11.1" ]
|
||||
then
|
||||
LOVE_AppImage_URL=https://github.com/love2d/love/releases/download/${VERSION}/love-${VERSION}-linux-${ARCH}.AppImage
|
||||
fi
|
||||
CACHE_DIR=${HOME}/.cache/love-release/love
|
||||
LOVE_AppImage=$CACHE_DIR/love-${VERSION}-${ARCH}.AppImage
|
||||
|
||||
if ! test -d ${CACHE_DIR}; then
|
||||
mkdir -p ${CACHE_DIR}
|
||||
fi
|
||||
|
||||
get-development-artifact(){
|
||||
owner=love2d
|
||||
repo=love
|
||||
branch="12.0-development"
|
||||
artifact="love-x86_64.AppImage" # love-windows-x64 love-macos
|
||||
token=$2
|
||||
username=$1
|
||||
list_run_url="https://api.github.com/repos/${owner}/${repo}/actions/runs"
|
||||
echo "find latest run of branch 12.0"
|
||||
latest_run=$(curl -v --silent \
|
||||
-H "Accept: application/vnd.github.v3+json" \
|
||||
-H "Authorization token ${token}" "${list_run_url}" \
|
||||
--stderr - |\
|
||||
grep -B 4 "\"head_branch\": \"12.0-development\"" |\
|
||||
grep "id" |\
|
||||
head -1 |\
|
||||
sed 's/^.* \(.*\),$/\1/g')
|
||||
list_artifacts_url="https://api.github.com/repos/${owner}/${repo}/actions/runs/${latest_run}/artifacts"
|
||||
echo "get artifact_url"
|
||||
artifact_url=$(curl --silent \
|
||||
-H "Accept: application/vnd.github.v3+json" \
|
||||
-H "Authorization token ${token}" \
|
||||
"${list_artifacts_url}" \
|
||||
--stderr - |\
|
||||
grep -A 5 "\"name\": \"${artifact}\"," |\
|
||||
grep "archive_download_url" |\
|
||||
head -1 |\
|
||||
sed 's/^.* \"\(.*\)\",$/\1/g')
|
||||
echo "download target"
|
||||
echo curl -L -u ${username}:${token} ${artifact_url} -o love.zip
|
||||
echo $(pwd)
|
||||
rm -f love.zip love-*.AppImage && \
|
||||
curl -L -u ${username}:${token} ${artifact_url} -o love.zip \
|
||||
&& unzip love.zip && \
|
||||
rm -f love.zip ${artifact} && \
|
||||
mv love-*.AppImage ${artifact}
|
||||
}
|
||||
|
||||
if ! test -f ${LOVE_AppImage}; then
|
||||
if [ $VERSION != "12.0" ]
|
||||
then
|
||||
curl -L -C - -o ${LOVE_AppImage} ${LOVE_AppImage_URL}
|
||||
else
|
||||
get-development-artifact $USERNAME $TOKEN
|
||||
mv love-x86_64.AppImage ${LOVE_AppImage}
|
||||
fi
|
||||
chmod +x ${LOVE_AppImage}
|
||||
fi
|
||||
|
||||
echo $CACHE_DIR
|
||||
|
||||
if ! test -f ${LOVE_AppImage}; then
|
||||
echo "No tarball found for $VERSION in $LOVE_AppImage"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
download_if_needed() {
|
||||
if ! test -f "$1"; then
|
||||
if ! curl -L -o "$1" "https://github.com/AppImage/AppImageKit/releases/download/${CURRENT_APPIMAGEKIT_RELEASE}/$1"; then
|
||||
echo "Failed to download appimagetool"
|
||||
echo "Please supply it manually"
|
||||
exit 1
|
||||
fi
|
||||
chmod +x "$1"
|
||||
fi
|
||||
}
|
||||
|
||||
main() {
|
||||
download_if_needed appimagetool-${ARCH}.AppImage
|
||||
# Extract the tarball build into a folder
|
||||
rm -rf love-prepared
|
||||
mkdir -p love-prepared
|
||||
cd love-prepared
|
||||
$LOVE_AppImage --appimage-extract 1> /dev/null 2> /dev/null
|
||||
mv squashfs-root/* .
|
||||
rm squashfs-root/.DirIcon
|
||||
rmdir squashfs-root
|
||||
# Add our small wrapper script (yay, more wrappers), and AppRun
|
||||
local desktopfile="love.desktop"
|
||||
local icon="love"
|
||||
local target="love-${VERSION}"
|
||||
|
||||
if test -f ../../game.desktop.in; then
|
||||
desktopfile="game.desktop"
|
||||
cp ../../game.desktop.in .
|
||||
fi
|
||||
if test -f ../../game.svg; then
|
||||
icon="game"
|
||||
cp ../../game.svg .
|
||||
fi
|
||||
if test -f ${LOVEFILE}; then
|
||||
if [[ $VERSION == "11.4" || $VERSION == "11.5" || $VERSION == "12.0" ]]
|
||||
then
|
||||
dir="bin"
|
||||
else
|
||||
dir="usr/bin"
|
||||
fi
|
||||
target="game"
|
||||
cat $dir/love ${LOVEFILE} > $dir/love-fused
|
||||
mv $dir/love-fused $dir/love
|
||||
chmod +x $dir/love
|
||||
else
|
||||
echo "Love file ${LOVEFILE} not found"
|
||||
fi
|
||||
|
||||
# Add our desktop file
|
||||
mv ${desktopfile} ${desktopfile}.in
|
||||
sed -e "s/%ICON%/${icon}/" "${desktopfile}.in" > "$desktopfile"
|
||||
rm "${desktopfile}.in"
|
||||
|
||||
# Add a DirIcon
|
||||
cp "${icon}.svg" .DirIcon
|
||||
|
||||
# Clean up
|
||||
if test -f ../../game.desktop.in; then
|
||||
rm love.desktop.in
|
||||
fi
|
||||
if test -f ../../game.svg; then
|
||||
rm love.svg
|
||||
fi
|
||||
|
||||
# Now build the final AppImage
|
||||
cd ..
|
||||
|
||||
# ./love-prepared/AppRun -n love-prepared "${target}-${ARCH}.AppImage"
|
||||
# Work around missing FUSE/docker
|
||||
./appimagetool-${ARCH}.AppImage --appimage-extract 1> /dev/null 2> /dev/null
|
||||
./squashfs-root/AppRun -n love-prepared "${target}-${ARCH}.AppImage" 1> /dev/null 2> /dev/null
|
||||
## rm -rf love-prepared/
|
||||
}
|
||||
|
||||
main "$@"
|
Loading…
Add table
Add a link
Reference in a new issue