2019-07-09 09:35:01 +00:00
# Maintainer: Saren Arterius <saren@wtako.net>
# Maintainer: Térence Clastres <t.clastres@gmail.com>
# Maintainer: Jan Alexander Steffens (heftig) <jan.steffens@gmail.com>
# Maintainer: Ionut Biru <ibiru@archlinux.org>
# Contributor: Michael Kanis <mkanis_at_gmx_dot_de>
2019-10-27 16:13:34 +00:00
### MERGE REQUESTS SELECTION
2019-11-09 07:54:38 +00:00
# available MR: ('!429' '!493' '!575' '!579' !719 '!724' '!762')
# _merge_requests_to_use=('!493' '!575' '!579' !719 '!724' '!762')
2019-11-30 15:27:52 +00:00
_merge_requests_to_use = ( '!575' '!724' )
2019-10-27 16:13:34 +00:00
### IMPORTANT: Do no edit below this line unless you know what you're doing
2019-07-09 09:35:01 +00:00
pkgname = mutter-performance
2019-11-30 15:27:52 +00:00
pkgver = 3.34.1+66+gc0e76186d
2019-11-04 12:39:39 +00:00
pkgrel = 1
2019-07-09 09:38:09 +00:00
pkgdesc = "A window manager for GNOME | Attempts to improve performances with non-upstreamed merge-requests and frequent stable branch resync"
url = "https://gitlab.gnome.org/GNOME/mutter"
2019-07-09 09:35:01 +00:00
arch = ( x86_64)
license = ( GPL)
depends = ( dconf gobject-introspection-runtime gsettings-desktop-schemas libcanberra
startup-notification zenity libsm gnome-desktop upower libxkbcommon-x11
2019-09-20 04:41:54 +00:00
gnome-settings-daemon libgudev libinput pipewire xorg-server-xwayland)
makedepends = ( gobject-introspection git egl-wayland meson xorg-server "sysprof>=3.34" )
2019-07-09 09:35:01 +00:00
checkdepends = ( xorg-server-xvfb)
2019-07-09 23:08:20 +00:00
provides = ( mutter mutter-781835-workaround)
2019-07-09 09:35:01 +00:00
conflicts = ( mutter)
2019-07-09 11:42:54 +00:00
replaces = ( mutter-781835-workaround)
2019-07-09 09:35:01 +00:00
groups = ( gnome)
2019-12-28 19:30:17 +00:00
install = mutter.install
2019-11-30 15:27:52 +00:00
_commit = c0e76186da5b7baf7c8804c0ffa80232a5a6bf98 # gnome-3-34
2019-10-20 21:49:26 +00:00
source = ( " $pkgname ::git+https://gitlab.gnome.org/GNOME/mutter.git#commit= $_commit "
2019-12-28 19:30:17 +00:00
0001-EGL-Include-EGL-eglmesaext.h.patch
0002-surface-actor-wayland-Do-not-send-frame-callbacks-if.patch
0003-xwayland-Do-not-queue-frame-callbacks-unconditionall.patch)
2019-10-20 21:49:26 +00:00
sha256sums = ( 'SKIP'
2019-12-28 19:30:17 +00:00
'8440403c1862187b648e3ddd20056666f1a9fea38d0511d7bdf4422ce70b4139'
'9f6881cd9fe2031b7119288972d3b921358f387b8cbfbd4c624a0dc33abce8e2'
'0ad4084834b6314873d2dc0a9c8bb3b30f0a6106fa44aac98a54129ec0fc0b2c' )
2019-07-09 09:35:01 +00:00
pkgver( ) {
cd $pkgname
git describe --tags | sed 's/-/+/g'
}
2019-08-20 11:55:46 +00:00
hash_of( ) {
git log --oneline --all | grep " $1 " | tail -n 1 | awk '{print $1}'
}
git_cp_by_msg( ) {
# Comment: Saren found a way to fetch hash based on commit name. It's controversial but might be interesting to create a function to call for each MR to not have to update the hash at each rebase.
h_first = $( hash_of " $2 " )
if [ [ -n " $3 " ] ] ; then
h_last = $( hash_of " $3 " )
echo " Found $h_first ^ $h_last for $1 "
git cherry-pick -n -Xtheirs $h_first ^..$h_last
else
echo " Found $h_first for $1 "
git cherry-pick -n -Xtheirs $h_first
fi
}
2019-10-27 16:13:34 +00:00
pick_mr( ) {
for mr in " ${ _merge_requests_to_use [@] } " ; do
if [ " $1 " = " $mr " ] ; then
if [ " $3 " = "merge" ] ; then
echo " Merging $1 ... "
git cherry-pick -n $2
elif [ " $3 " = "revert" ] ; then
echo " Reverting $1 ... "
git revert " $2 " --no-commit
else
echo " Merging latest commits for $1 ... "
git_cp_by_msg " $1 " " $2 " " $3 "
fi
break
fi
done
}
2019-07-09 09:35:01 +00:00
prepare( ) {
cd $pkgname
### Adding and fetching remotes providing the selected merge-requests
2019-11-09 07:54:38 +00:00
git reset --hard
2019-08-20 11:55:46 +00:00
git cherry-pick --abort || true
2019-07-09 09:35:01 +00:00
git remote add vanvugt https://gitlab.gnome.org/vanvugt/mutter.git || true
2019-11-09 07:54:38 +00:00
# git remote add verdre https://gitlab.gnome.org/verdre/mutter.git || true # !429
2019-11-04 12:14:38 +00:00
git remote add 3v1no https://gitlab.gnome.org/3v1n0/mutter.git || true
2019-07-09 09:35:01 +00:00
git fetch vanvugt
2019-11-09 07:54:38 +00:00
# git fetch verdre
2019-11-04 12:14:38 +00:00
git fetch 3v1no
2019-07-09 09:35:01 +00:00
### Merge Requests
# Merge Request Prototype
# Title:
# URL:
# Type:
# Status:
# Comment:
# git cherry-pick -n first_commit^..last_commit
#
# 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.
#
# Possible Type:
# 1. Improvement: Makes an already existing feature behave better, more efficiently/reliably.
# 2. Feature: Adds a new functionality.
2019-07-16 16:26:02 +00:00
# 3. Fix: Regression/bug fix only available in master (not backported).
2019-07-09 09:35:01 +00:00
# 4. Cleanup: Code styling improvement, function deprecation, rearrangement...
# Title: Resource scale computation optimizations
# URL: https://gitlab.gnome.org/GNOME/mutter/merge_requests/493
# Type: 1
# Status: 3
2019-10-27 16:13:34 +00:00
# Comment: Not picked by default because breaks the overview on Wayland. https://gitlab.gnome.org/GNOME/mutter/merge_requests/493#note_549833
pick_mr '!493' 3aa449af^..1017ce44 'merge'
2019-07-09 09:35:01 +00:00
# Title: Honour `CLUTTER_ACTOR_NO_LAYOUT` more efficiently
# URL: https://gitlab.gnome.org/GNOME/mutter/merge_requests/575
# Type: 1
# Status: 2
2019-10-27 16:13:34 +00:00
pick_mr '!575' 'clutter/stage: Add an API for shallow relayouts' 'clutter/actor: Use the new shallow relayout API'
2019-07-09 09:35:01 +00:00
2019-07-27 22:39:16 +00:00
# Title: clutter/stage: Update input devices right after doing a relayout
# URL: https://gitlab.gnome.org/GNOME/mutter/merge_requests/429
# Type: 1
2019-09-20 04:41:54 +00:00
# Status: 1
2019-10-27 16:13:34 +00:00
pick_mr '!429' 'clutter/stage-cogl: Add method to check if ongoing repaint is clipped' 'clutter/stage: Use a device-manager method to update input devices'
2019-08-06 12:04:10 +00:00
2019-08-20 12:40:45 +00:00
# Title: Sync timelines to hardware vsync
# URL: https://gitlab.gnome.org/GNOME/mutter/merge_requests/724
# Type: 1
# Status: 2
# Comment:
2019-10-27 16:13:34 +00:00
pick_mr '!724' 'clutter/stage: Add API to get_next_presentation_time' 'clutter/master-clock-default: Sync timelines to hardware vsync'
2019-10-09 02:28:20 +00:00
2019-10-28 16:24:42 +00:00
# Title: backends: Do not reload keymap on new keyboard notifications
# URL: https://gitlab.gnome.org/GNOME/mutter/merge_requests/579
# Type: 1
# Status: 4
# Comment: Was reverted: https://gitlab.gnome.org/GNOME/mutter/merge_requests/833
# If you use stenography software or play hardcore rhythm games like Lunatic Rave 2/osumania, use it.
2019-10-27 16:13:34 +00:00
pick_mr '!579' ce86f90efbaa51522ba14c5b4cad933c2106de42 'revert'
2019-10-09 02:28:20 +00:00
2019-10-28 16:24:42 +00:00
# Title: https://gitlab.gnome.org/GNOME/mutter/merge_requests/719
# URL: https://gitlab.gnome.org/GNOME/mutter/merge_requests/719
# Type: 1
# Status: 4
# Comment: Was reverted: https://gitlab.gnome.org/GNOME/mutter/commit/97140ab6346bd29208e99c9c9aab892c2eec0e52
# Use together with !762 to fix one of its issues.
pick_mr '!719' 97140ab6346bd29208e99c9c9aab892c2eec0e52 'revert'
pick_mr '!762' e9ba9dc2 'merge'
2019-12-28 19:30:17 +00:00
# fix build with libglvnd's EGL headers
git apply -3 ../0001-EGL-Include-EGL-eglmesaext.h.patch
2019-11-09 07:54:38 +00:00
# https://gitlab.gnome.org/GNOME/mutter/merge_requests/918
2019-12-28 19:30:17 +00:00
git apply -3 ../0002-surface-actor-wayland-Do-not-send-frame-callbacks-if.patch
2019-11-04 12:14:38 +00:00
2019-12-28 19:30:17 +00:00
# https://gitlab.gnome.org/GNOME/mutter/merge_requests/956
git apply -3 ../0003-xwayland-Do-not-queue-frame-callbacks-unconditionall.patch
2019-10-20 21:49:26 +00:00
2019-07-09 09:35:01 +00:00
}
build( ) {
arch-meson $pkgname build \
-D egl_device = true \
-D wayland_eglstream = true \
-D installed_tests = false
ninja -C build
}
2019-09-20 04:41:54 +00:00
check( ) (
mkdir -p -m 700 " ${ XDG_RUNTIME_DIR : = $PWD /runtime-dir } "
glib-compile-schemas " ${ GSETTINGS_SCHEMA_DIR : = $PWD /build/data } "
export XDG_RUNTIME_DIR GSETTINGS_SCHEMA_DIR
# Unexpected passes in conform test
# Stacking test flaky
dbus-run-session xvfb-run -s '+iglx -noreset' meson test -C build --print-errorlogs || :
)
2019-07-09 09:35:01 +00:00
package( ) {
DESTDIR = " $pkgdir " meson install -C build
}