1
0
Fork 0
gnome-shell-performance-pkg.../PKGBUILD

171 lines
5.7 KiB
Text
Raw Normal View History

# Patched package:
# Maintainer: Saren Arterius <saren@wtako.net>
# Co-maintainer: Térence Clastres <t.clastres@gmail.com>
# Co-maintainer: Sung Mingi <FiestaLake@protonmail.com>
# Official package:
# Maintainer: Jan Alexander Steffens (heftig) <heftig@archlinux.org>
2018-08-04 18:19:38 +00:00
# Contributor: Ionut Biru <ibiru@archlinux.org>
# Contributor: Flamelab <panosfilip@gmail.com
### MERGE REQUESTS SELECTION
# available MR: ('1884' '1915')
_merge_requests_to_use=('1884' '1915')
### IMPORTANT: Do no edit below this line unless you know what you're doing
2018-08-04 18:19:38 +00:00
pkgname=gnome-shell-performance
2019-10-04 03:28:59 +00:00
_pkgname=gnome-shell
pkgver=42.1+2+g65831f783
pkgrel=1
epoch=1
pkgdesc="Next generation desktop shell | Attempts to improve performances with non-upstreamed merge-requests and frequent stable branch resync"
2018-08-04 18:19:38 +00:00
url="https://wiki.gnome.org/Projects/GnomeShell"
arch=(x86_64)
2021-04-21 11:01:28 +00:00
license=(GPL)
depends=(accountsservice gcr gjs gnome-bluetooth-3.0 upower gnome-session gtk4
gnome-settings-daemon gsettings-desktop-schemas libcanberra-pulse
libgdm libsecret mutter libnma unzip gstreamer libibus gnome-autoar
gnome-disk-utility gst-plugin-pipewire libsoup3 libgweather-4)
2021-04-21 11:01:28 +00:00
makedepends=(gtk-doc gnome-control-center evolution-data-server
gobject-introspection git meson sassc asciidoc bash-completion)
checkdepends=(xorg-server-xvfb)
2018-08-04 18:19:38 +00:00
optdepends=('gnome-control-center: System settings'
'evolution-data-server: Evolution calendar integration')
2018-08-04 18:19:38 +00:00
groups=(gnome)
provides=(gnome-shell gnome-shell=$pkgver gnome-shell=$epoch:$pkgver)
2018-08-04 18:19:38 +00:00
conflicts=(gnome-shell)
_commit=65831f783ec3d0f13553d3c4534772a585cf4009 # tags/42.1^2
2019-10-04 03:28:59 +00:00
source=("git+https://gitlab.gnome.org/GNOME/gnome-shell.git#commit=$_commit"
"git+https://gitlab.gnome.org/GNOME/libgnome-volume-control.git"
"mr1884.patch"
"mr1915.patch")
2018-08-04 18:19:38 +00:00
sha256sums=('SKIP'
'SKIP'
'da73e9bb8199135808e9cb7fa2b9aebd8ed4cfd215fffeb94d919de50e18ab73'
'70981733587a988b846b75e52077e5e986ddd38601667b037d1b0950304ea015')
2019-09-20 04:41:02 +00:00
2019-03-15 21:09:49 +00:00
pkgver() {
2019-10-04 03:28:59 +00:00
cd $_pkgname
2019-09-20 04:41:02 +00:00
git describe --tags | sed 's/-/+/g'
2019-03-15 21:09:49 +00:00
}
2018-08-04 18:19:38 +00:00
pick_mr() {
for mr in "${_merge_requests_to_use[@]}"; do
if [ "$1" = "$mr" ]; then
if [ "$2" = "merge" ] || [ -z "$2" ]; then
echo "Downloading then Merging $1..."
2020-04-27 22:15:37 +00:00
curl -O "https://gitlab.gnome.org/GNOME/gnome-shell/-/merge_requests/$mr.diff"
git apply "$mr.diff"
elif [ "$3" = "revert" ]; then
echo "Reverting $1..."
git revert "$2" --no-commit
elif [ "$3" = "patch" ]; then
2020-12-13 15:14:04 +00:00
if [ -e ../"$2" ]; then
echo "Patching with $2..."
patch -Np1 -i ../"$2"
else
echo "Downloading $mr as $2 then patching..."
curl -O "https://gitlab.gnome.org/GNOME/gnome-shell/-/merge_requests/$mr.diff" -o "$2"
patch -Np1 -i "$2"
fi
else
echo "ERROR: wrong argument given: $2"
fi
break
fi
done
}
2018-09-18 02:17:53 +00:00
prepare() {
2019-10-04 03:28:59 +00:00
cd $_pkgname
2019-03-16 15:43:10 +00:00
2019-07-09 12:36:07 +00:00
### Adding and fetching remotes providing the selected merge-requests
### Only needed when there is no MR opened
2019-07-09 12:36:07 +00:00
git reset --hard
git cherry-pick --abort || true
2019-10-04 03:28:59 +00:00
# git remote add verde https://gitlab.gnome.org/verdre/gnome-shell.git || true
# git fetch verde
# git remote add 3v1n0 https://gitlab.gnome.org/3v1n0/gnome-shell || true
# git fetch 3v1n0
# git remote add vanvugt https://gitlab.gnome.org/vanvugt/gnome-shell.git || true
# git fetch vanvugt
2019-07-09 12:36:07 +00:00
### Merge Requests
# Merge Request Prototype
# Title:
# URL:
# Type:
# Status:
# Comment:
# git cherry-pick -n first_commit^..last_commit
#
# Possible Type:
# 1. Improvement: Makes an already existing feature behave better, more efficiently/reliably.
# 2. Feature: Adds a new functionality.
# 3. Fix: Regression/bug fix only available in master (not backported).
# 4. Cleanup: Code styling improvement, function deprecation, rearrangement...
#
2019-07-09 12:36:07 +00:00
# Possible Status:
# 1. Needs rebase: Conflicts with master branch.
# 2. Needs review: Mutter maintainers needs to review the new/updated MR and provide feedback.
# 3. Needs changes: MR needs to be adjusted based on maintainers feedback.
# 4. Merged: MR approved and it changes commited to master.
#
# Generally, a MR status oscillate between 2 and 3 and then becomes 4.
# Title: Fade out whole icons instead of using StScrollViewFade (traditional design)
# URL: https://gitlab.gnome.org/GNOME/gnome-shell/-/merge_requests/1884
2020-01-11 18:26:36 +00:00
# Type: 1
# Status: 2
# Comment: By avoiding StScrollViewFade we avoid offscreening and therefore
# avoid painting everything twice to get it on screen. So this almost
# halves the render time of the icon grid.
# Related: #4367, !1877, #174
pick_mr '1884' 'mr1884.patch' 'patch'
2020-01-11 18:26:36 +00:00
# Title: Optimize box-shadow rendering (part 2) [chroma key design]
# URL: https://gitlab.gnome.org/GNOME/gnome-shell/-/merge_requests/1915
# Type: 1
# Status: 2
# Comment: This reduces the render time of the overview by about 15%.
# Part 1 was in !1904 (merged).
# This is an alternate design to !1862.
pick_mr '1915' 'mr1915.patch' 'patch'
2018-08-04 18:19:38 +00:00
git submodule init
2020-03-09 03:58:01 +00:00
git submodule set-url subprojects/gvc "$srcdir/libgnome-volume-control"
2018-08-04 18:19:38 +00:00
git submodule update
}
2019-10-15 01:16:37 +00:00
2018-08-04 18:19:38 +00:00
build() {
CFLAGS="${CFLAGS/-O2/-O3} -fno-semantic-interposition"
LDFLAGS+=" -Wl,-Bsymbolic-functions"
2019-10-04 03:28:59 +00:00
arch-meson $_pkgname build -D gtk_doc=true
2020-06-16 13:37:43 +00:00
meson compile -C build
2018-08-04 18:19:38 +00:00
}
_check() (
2021-04-21 11:01:28 +00:00
mkdir -p -m 700 "${XDG_RUNTIME_DIR:=$PWD/runtime-dir}"
export XDG_RUNTIME_DIR
meson test -C build --print-errorlogs
2021-04-21 11:01:28 +00:00
)
check() {
dbus-run-session xvfb-run -s '-nolisten local +iglx -noreset' \
bash -c "$(declare -f _check); _check"
}
2018-08-04 18:19:38 +00:00
package() {
depends+=(libmutter-10.so)
2021-05-14 22:18:10 +00:00
meson install -C build --destdir "$pkgdir"
2019-10-15 01:16:37 +00:00
}