diff options
Diffstat (limited to 'PKGBUILD')
-rw-r--r-- | PKGBUILD | 75 |
1 files changed, 55 insertions, 20 deletions
@@ -1,28 +1,63 @@ -# Maintainer: Anty0 <anty150 at gmail dot com> +# Contributor: Lex Black <autumn-wind@web.de> +# Contributor: Anty0 <anty150 at gmail dot com> - -# Helper variables for updaurpkg (https://aur.archlinux.org/packages/updaurpkg-git) -_upstreamver='v2.14.0' -_upstreamver_regex='^v[0-9]+\.[0-9]+\.[0-9]+$' -_source_type='github-releases' -_repo='nextcloud-releases/files_texteditor' - - -pkgdesc='The original text editor app for Nextcloud, based on Ace' -pkgname=('nextcloud-app-files-texteditor') -_nextcloud_appname='files_texteditor' -pkgver="${_upstreamver:1}" +_name=files_texteditor +pkgname=nextcloud-app-files-texteditor +pkgver=2.15.1 pkgrel=1 +pkgdesc='The original text editor app for Nextcloud, based on Ace' arch=('any') +url="https://github.com/nextcloud/files_texteditor" license=('AGPL') -url="https://github.com/${_repo}" -makedepends=() -depends=('nextcloud') +makedepends=('nextcloud' 'yq') options=('!strip') -source=("files_texteditor-v${pkgver}.tar.gz::${url}/releases/download/v${pkgver}/${_nextcloud_appname}.tar.gz") -sha512sums=('ba2dad5f541df894ea422cfc66dd6e2daefe99739cfda41cb081409b7dbc5238ef49bff560c28c2e149af25ddfb0084ead248b87156e185f3b14913a824ca5ca') +source=("${pkgname}-${pkgver}.tar.gz::https://github.com/nextcloud-releases/${_name}/releases/download/v${pkgver/_/-}/${_name}-v${pkgver/_/-}.tar.gz") +sha512sums=('2032ca9bfab527be56727d49107acf25caea132d62ed7a1f6286b634a188edd538c4b535c3ef683309fc8c1413ebe650b2da3d9eb541b4c7b18a69263037e6bc') + + +# BEGIN boilerplate nextcloud app version clamping, see also other packages in group +# 1. Call respective function helpers in check() and package() *after* cd'ing to the source directory +# 2. Add makedepends+=(nextcloud yq) +_phps=(php7 php php-legacy) +_get_supported_ranges() { + _app_min_nextcloud="$(< appinfo/info.xml xq -r '.info.dependencies.nextcloud["@min-version"] | values')" + _app_max_nextcloud="$(< appinfo/info.xml xq -r '.info.dependencies.nextcloud["@max-version"] | values | tonumber | .+1')" + _app_min_php="$(< appinfo/info.xml xq -r '.info.dependencies.php["@min-version"] | values')" + _app_max_php="$(< appinfo/info.xml xq -r '.info.dependencies.php["@max-version"] | values | tonumber | .+0.1')" +} +_unsupported_range() { + printf "%s requires %s %s, but %s %s is provided.\n" "$pkgname" "$1" "$2" "$1" "$3" + exit 1 +} +_nextcloud_app_check() { + _get_supported_ranges + for _php in "${_phps[@]}"; do command -v "$_php" > /dev/null && break; done + local _nextcloud_ver="$("$_php" <(cat /usr/share/webapps/nextcloud/version.php; echo 'print($OC_VersionString);'))" + local _php_ver="$("$_php" -r 'print(phpversion());')" + [[ "$(vercmp "${_app_min_nextcloud:-0}" "$_nextcloud_ver")" -le 0 ]] || \ + _unsupported_range nextcloud "=> $_app_min_nextcloud" "$_nextcloud_ver" + [[ "$(vercmp "${_app_max_nextcloud:-999}" "$_nextcloud_ver")" -gt 0 ]] || \ + _unsupported_range nextcloud "< $_app_max_nextcloud" "$_nextcloud_ver" + [[ "$(vercmp "${_app_min_php:-0}" "$_php_ver")" -le 0 ]] || \ + _unsupported_range php ">= $_app_min_php" "$_php_ver" + [[ "$(vercmp "${_app_max_php:-999}" "$_php_ver")" -gt 0 ]] || \ + _unsupported_range php "< $_app_max_php" "$_php_ver" +} +_nextcloud_app_package() { + _get_supported_ranges + depends+=("nextcloud>=${_app_min_nextcloud:-0}" "nextcloud<${_app_max_nextcloud:-999}") + depends+=("php-interpreter${_app_min_php:+>=$_app_min_php}" ${_app_max_php:+"php-interpreter<$_app_max_php"}) +} +# END boilerplate nextcloud app version clamping + +check() { + cd $_name + _nextcloud_app_check +} package() { - install -d "${pkgdir}/usr/share/webapps/nextcloud/apps" - cp -a "${srcdir}/${_nextcloud_appname}" "${pkgdir}/usr/share/webapps/nextcloud/apps/${_nextcloud_appname}" + install -vdm 755 "$pkgdir/usr/share/webapps/nextcloud/apps/" + cp -av $_name "$pkgdir/usr/share/webapps/nextcloud/apps/" + cd $_name + _nextcloud_app_package } |