blob: fd6781a296ace7813ff756b8111fca747fa92f7c (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
|
# Maintainer: Jan Alexander Steffens (heftig) <jan.steffens@gmail.com>
# Maintainer: Ionut Biru <ibiru@archlinux.org>
# Contributor: Michael Kanis <mkanis_at_gmx_dot_de>
# Patched package maintainer: Saren Arterius <saren@wtako.net>
# Patch origin: https://gist.github.com/DeadMetaler/12622bf9415c1100f2d436ffbd6778c6
pkgname=mutter-781835-workaround
_pkgname=mutter
pkgver=3.30.1+8+g1abab3fe2
pkgrel=3
pkgdesc="A window manager for GNOME. This package reverts a commit which may causes performance problems for nvidia driver users. Some performance patches also included."
url="https://gitlab.gnome.org/GNOME/mutter"
arch=(x86_64)
license=(GPL)
depends=(dconf gobject-introspection-runtime gsettings-desktop-schemas libcanberra
startup-notification zenity libsm gnome-desktop upower libxkbcommon-x11
gnome-settings-daemon libgudev libinput pipewire gnome-shell) # or gnome-shell-performance=3.28.3+7+g721ce5403
makedepends=(intltool gobject-introspection git egl-wayland)
provides=(mutter)
conflicts=(mutter)
groups=(gnome)
_commit=1abab3fe2ed2d07bafc9f3aabe188c4d1c05ee43 # gnome-3-30
source=("git+https://gitlab.gnome.org/GNOME/mutter.git#commit=$_commit"
https://gitlab.gnome.org/vanvugt/mutter/commit/fc02b040f3b750b0513f812813351c09795950f6.patch
startup-notification.patch
revert.patch)
sha256sums=('SKIP'
'dffa2ca19281b9fa5a81bf80bd46a8eae78325c7e1f8b2a25c33945aa7cc0903'
'00d5e77c94e83e1987cc443ed7c47303aa33367ce912b2f665bcd34f88890a17'
'2d2e305e0a6cca087bb8164f81bdc0ae7a5ca8e9c13c81d7fd5252eb3563fc09')
# pkgver() {
# cd $_pkgname
# # git describe --tags | sed 's/-/+/g'
# }
prepare() {
cd $_pkgname
## Unmerged performance bits
# Commented multiline comment start, remove the # below to disable the patches
# : '
git remote add vanvugt https://gitlab.gnome.org/vanvugt/mutter.git || true
git fetch vanvugt
# clutter: Deliver events sooner when possible
# https://gitlab.gnome.org/GNOME/mutter/merge_requests/168/commits
# Disabled as may cause stutter when using mouse with high polling rate
# git cherry-pick 0feecfe8
# clutter: Fix offscreen-effect painting of clones
# https://gitlab.gnome.org/GNOME/mutter/merge_requests/117/commits
git cherry-pick fb398c1c
# Geometric (GPU-less) picking
# https://gitlab.gnome.org/GNOME/mutter/merge_requests/189
git cherry-pick 0fe913fe
git cherry-pick 955d9c07
# Sync to the hardware refresh rate, not just 60.00Hz [performance]
# https://gitlab.gnome.org/GNOME/mutter/merge_requests/171/commits
git cherry-pick d29a1c4a
git cherry-pick 7575c7fa
# clutter-actor: Add detail to captured-event signal [performance]
# https://gitlab.gnome.org/GNOME/mutter/merge_requests/283/commits
git cherry-pick 544b95de
# cogl-winsys-glx: Fix frame notification race/leak [performance]
# https://gitlab.gnome.org/GNOME/mutter/merge_requests/216
git cherry-pick fc02b040
# '
# Commented multiline comment end, remove the # above if disabling the patches
# Revert offending commit
patch -Np1 -i ../revert.patch
# https://gitlab.gnome.org/GNOME/mutter/merge_requests/216
git apply -3 ../fc02b040f3b750b0513f812813351c09795950f6.patch
# https://bugs.archlinux.org/task/51940
# As of 2018-05-08: Still needed, according to fmuellner
git apply -3 ../startup-notification.patch
NOCONFIGURE=1 ./autogen.sh
}
build() {
cd $_pkgname
./configure --prefix=/usr --sysconfdir=/etc --localstatedir=/var \
--libexecdir=/usr/lib --disable-static \
--disable-schemas-compile --enable-compile-warnings=minimum \
--enable-gtk-doc --enable-egl-device --enable-remote-desktop
# https://bugzilla.gnome.org/show_bug.cgi?id=655517
sed -e 's/ -shared / -Wl,-O1,--as-needed\0/g' \
-i {.,cogl,clutter}/libtool
make
}
package() {
cd $_pkgname
make DESTDIR="$pkgdir" install
}
|