summarylogtreecommitdiffstats
diff options
context:
space:
mode:
authorzxp198210052024-05-11 08:58:44 +0800
committerzxp198210052024-05-11 08:58:44 +0800
commitbf5d37945b7444cdd0f56ad021ac4769117baca8 (patch)
treec1e59b2984601793789795fa481cd2e8f628a687
parent33dcfc5642fda4c67330b9efcd19921cb5627b37 (diff)
downloadaur-bf5d37945b7444cdd0f56ad021ac4769117baca8.tar.gz
fix errors
-rw-r--r--.SRCINFO11
-rw-r--r--.gitignore9
-rw-r--r--PKGBUILD43
-rw-r--r--sonixd.sh21
4 files changed, 51 insertions, 33 deletions
diff --git a/.SRCINFO b/.SRCINFO
index 2b49f9948fdb..ef8d69679c5f 100644
--- a/.SRCINFO
+++ b/.SRCINFO
@@ -1,7 +1,7 @@
pkgbase = sonixd
pkgdesc = A full-featured Subsonic/Jellyfin compatible desktop client
pkgver = 0.15.5
- pkgrel = 3
+ pkgrel = 4
url = https://github.com/jeffvli/sonixd
arch = x86_64
license = GPL-3.0-only
@@ -9,14 +9,15 @@ pkgbase = sonixd
makedepends = nvm
makedepends = npm
makedepends = python>=3
- makedepends = git
makedepends = base-devel
+ makedepends = gcc
makedepends = gendesk
+ makedepends = curl
depends = electron22
conflicts = sonixd
- source = sonixd.git::git+https://github.com/jeffvli/sonixd#tag=v0.15.5
+ source = sonixd-0.15.5.tar.gz::https://github.com/jeffvli/sonixd/archive/refs/tags/v0.15.5.tar.gz
source = sonixd.sh
- sha256sums = SKIP
- sha256sums = dc0c5ca385ad81a08315a91655c7c064b5bf110eada55e61265633ae198b39f8
+ sha256sums = 1de05c325a0e86c24f1c917c33f577645481e898d842134e7d5f8e6650916d5e
+ sha256sums = 41b6d61dffef064762b3eec3dfeca7a3e1f57cbcb6dce9a6940c06797a0eae9d
pkgname = sonixd
diff --git a/.gitignore b/.gitignore
deleted file mode 100644
index 50ee41fec863..000000000000
--- a/.gitignore
+++ /dev/null
@@ -1,9 +0,0 @@
-*
-
-!.gitignore
-!PKGBUILD
-!.SRCINFO
-!*.patch
-!*.diff
-!sonixd
-!*.desktop
diff --git a/PKGBUILD b/PKGBUILD
index f0794b06920c..4d890e4d29ce 100644
--- a/PKGBUILD
+++ b/PKGBUILD
@@ -5,7 +5,7 @@ _pkgname=Sonixd
pkgver=0.15.5
_electronversion=22
_nodeversion=16
-pkgrel=3
+pkgrel=4
pkgdesc="A full-featured Subsonic/Jellyfin compatible desktop client"
arch=('x86_64')
url="https://github.com/jeffvli/sonixd"
@@ -19,16 +19,17 @@ makedepends=(
'nvm'
'npm'
'python>=3'
- 'git'
'base-devel'
+ 'gcc'
'gendesk'
+ 'curl'
)
source=(
- "${pkgname}.git::git+${url}#tag=v${pkgver}"
+ "${pkgname}-${pkgver}.tar.gz::${url}/archive/refs/tags/v${pkgver}.tar.gz"
"${pkgname}.sh"
)
-sha256sums=('SKIP'
- 'dc0c5ca385ad81a08315a91655c7c064b5bf110eada55e61265633ae198b39f8')
+sha256sums=('1de05c325a0e86c24f1c917c33f577645481e898d842134e7d5f8e6650916d5e'
+ '41b6d61dffef064762b3eec3dfeca7a3e1f57cbcb6dce9a6940c06797a0eae9d')
_ensure_local_nvm() {
export NVM_DIR="${srcdir}/.nvm"
source /usr/share/nvm/init-nvm.sh || [[ $? != 1 ]]
@@ -39,29 +40,41 @@ build() {
sed -e "s|@electronversion@|${_electronversion}|" \
-e "s|@appname@|${pkgname}|g" \
-e "s|@runname@|app.asar|g" \
+ -e "s|@cfgdirname@|${_pkgname}|g" \
+ -e "s|@options@||g" \
-i "${srcdir}/${pkgname}.sh"
_ensure_local_nvm
gendesk -q -f -n --categories="Development" --name="${_pkgname}" --exec="${pkgname} %U"
- cd "${srcdir}/${pkgname}.git"
+ cd "${srcdir}/${pkgname}-${pkgver}"
export npm_config_build_from_source=true
- export ELECTRON_SKIP_BINARY_DOWNLOAD=1
- export SYSTEM_ELECTRON_VERSION="$(electron${_electronversion} -v | sed 's/v//g')"
- export npm_config_target="${SYSTEM_ELECTRON_VERSION}"
- export ELECTRONVERSION="${_electronversion}"
- export npm_config_disturl=https://electronjs.org/headers
+ #export ELECTRON_SKIP_BINARY_DOWNLOAD=1
+ #export SYSTEM_ELECTRON_VERSION="$(electron${_electronversion} -v | sed 's/v//g')"
+ #export npm_config_target="${SYSTEM_ELECTRON_VERSION}"
+ #export ELECTRONVERSION="${_electronversion}"
HOME="${srcdir}/.electron-gyp"
mkdir -p "${srcdir}/.electron-gyp"
touch "${srcdir}/.electron-gyp/.yarnrc"
- sed "s|electron-builder build|electron-builder -l AppImage|g" -i package.json
+ if [ `curl -s ipinfo.io/country | grep CN | wc -l ` -ge 1 ];then
+ export npm_config_registry=https://registry.npmmirror.com
+ export npm_config_disturl=https://registry.npmmirror.com/-/binary/node/
+ export npm_config_electron_mirror=https://registry.npmmirror.com/-/binary/electron/
+ export npm_config_electron_builder_binaries_mirror=https://registry.npmmirror.com/-/binary/electron-builder-binaries/
+ else
+ echo "Your network is OK."
+ fi
+ sed '/"AppImage",/d;s|"tar.xz"|"dir"|g' -i package.json
yarn install --cache-folder "${srcdir}/.yarn_cache"
yarn run package
+ asar e "${srcdir}/${pkgname}-${pkgver}/release/linux-"*/resources/app.asar "${srcdir}/app.asar.unpacked"
+ sed "s|process.resourcesPath,\"assets\"|\"\/usr\/lib\/${pkgname%-bin}\",\"assets\"|g" -i "${srcdir}/app.asar.unpacked/main.prod.js"
+ asar p "${srcdir}/app.asar.unpacked" "${srcdir}/app.asar"
}
package() {
install -Dm755 "${srcdir}/${pkgname}.sh" "${pkgdir}/usr/bin/${pkgname}"
- install -Dm644 "${srcdir}/${pkgname}.git/release/linux-"*/resources/app.asar -t "${pkgdir}/usr/lib/${pkgname}"
- cp -r "${srcdir}/${pkgname}.git/release/linux-"*/resources/{app.asar.unpacked,assets} "${pkgdir}/usr/lib/${pkgname}"
+ install -Dm644 "${srcdir}/app.asar" -t "${pkgdir}/usr/lib/${pkgname}"
+ cp -r "${srcdir}/${pkgname}-${pkgver}/release/linux-"*/resources/{app.asar.unpacked,assets} "${pkgdir}/usr/lib/${pkgname}"
for _icons in 16x16 24x24 32x32 48x48 64x64 96x96 128x128 256x256 512x512 1024x1024;do
- install -Dm644 "${srcdir}/${pkgname}.git/assets/icons/${_icons}.png" \
+ install -Dm644 "${srcdir}/${pkgname}-${pkgver}/assets/icons/${_icons}.png" \
"${pkgdir}/usr/share/icons/hicolor/${_icons}/apps/${pkgname}.png"
done
install -Dm644 "${srcdir}/${pkgname}.desktop" -t "${pkgdir}/usr/share/applications"
diff --git a/sonixd.sh b/sonixd.sh
index 7ddcaab8d734..398398461fee 100644
--- a/sonixd.sh
+++ b/sonixd.sh
@@ -1,16 +1,29 @@
#!/bin/bash
-set -e
+set -o pipefail
_APPDIR="/usr/lib/@appname@"
_RUNNAME="${_APPDIR}/@runname@"
+_CFGDIR="@cfgdirname@/"
_OPTIONS="@options@"
export PATH="${_APPDIR}:${PATH}"
export LD_LIBRARY_PATH="${_APPDIR}/swiftshader:${_APPDIR}/lib:${LD_LIBRARY_PATH}"
export ELECTRON_IS_DEV=0
export ELECTRON_FORCE_IS_PACKAGED=true
+export ELECTRON_DISABLE_SECURITY_WARNINGS=true
+export ELECTRON_OVERRIDE_DIST_PATH="/usr/bin/electron@electronversion@"
export NODE_ENV=production
+export XDG_CONFIG_HOME="${XDG_CONFIG_HOME:-$HOME/.config}"
+export _FLAGS_FILE="${XDG_CONFIG_HOME}/${_CFGDIR}@appname@-flags.conf"
+declare -a _USER_FLAGS
+if [[ -f "${_FLAGS_FILE}" ]]; then
+ while read -r line; do
+ if [[ ! "${line}" =~ ^[[:space:]]*#.* ]]; then
+ _USER_FLAGS+=("${line}")
+ fi
+ done < "${_FLAGS_FILE}"
+fi
cd "${_APPDIR}"
-if [[ $EUID -ne 0 ]] || [[ $ELECTRON_RUN_AS_NODE ]]; then
- exec electron@electronversion@ "${_RUNNAME}" "${_OPTIONS}" "$@" || exit $?
+if [[ "${EUID}" -ne 0 ]] || [[ "${ELECTRON_RUN_AS_NODE}" ]]; then
+ exec electron@electronversion@ "${_RUNNAME}" "${_OPTIONS}" "${_USER_FLAGS[@]}" "$@"
else
- exec electron@electronversion@ "${_RUNNAME}" "${_OPTIONS}" --no-sandbox "$@" || exit $?
+ exec electron@electronversion@ "${_RUNNAME}" "${_OPTIONS}" --no-sandbox "${_USER_FLAGS[@]}" "$@"
fi \ No newline at end of file