summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJan Novotný <[email protected]>2022-11-07 15:32:33 +0100
committerraveit65 <[email protected]>2022-11-12 17:27:19 +0100
commitd3add65f6960dd3c95aaa2fe63cc8c563747695d (patch)
treedda02a7007261af5bd0b911a431772e9055801dd
parent85ce3f72a00c620aa7631b33eba1e8f4fc8b131f (diff)
downloadmarco-d3add65f6960dd3c95aaa2fe63cc8c563747695d.tar.bz2
marco-d3add65f6960dd3c95aaa2fe63cc8c563747695d.tar.xz
replace _NET_WM_PID with XResGetClientPid (#741)
window-props: use XResQueryClientIds to get pid _NET_WM_PID is unreliable! It can be faked or pid might be from different namespace. Ignore _NET_WM_PID and use XResQueryClientIds to get pid. https://gitlab.gnome.org/GNOME/metacity/-/commit/bcbe966511362a8eb8c8c64035ab160086c931f8
-rw-r--r--.build.yml4
-rw-r--r--configure.ac2
-rw-r--r--meson.build3
-rw-r--r--src/core/window-props.c46
4 files changed, 54 insertions, 1 deletions
diff --git a/.build.yml b/.build.yml
index 6c77a8e5..fbaf6c5d 100644
--- a/.build.yml
+++ b/.build.yml
@@ -14,6 +14,7 @@ requires:
- libcanberra
- libgtop
- libxpresent
+ - libxres
- make
- mate-common
- mate-desktop
@@ -51,6 +52,7 @@ requires:
- libxpresent-dev
- libxrandr-dev
- libxrender-dev
+ - libxres-dev
- libxt-dev
- make
- mate-common
@@ -71,6 +73,7 @@ requires:
- libSM-devel
- libXdamage-devel
- libXpresent-devel
+ - libXres-devel
- libcanberra-devel
- libgtop2-devel
- libsoup-devel
@@ -109,6 +112,7 @@ requires:
- libxpresent-dev
- libxrandr-dev
- libxrender-dev
+ - libxres-dev
- libxt-dev
- make
- mate-common
diff --git a/configure.ac b/configure.ac
index 6b946ab6..d5002477 100644
--- a/configure.ac
+++ b/configure.ac
@@ -164,7 +164,7 @@ if test x$have_xcomposite = xyes; then
fi
if test x$have_xcomposite = xyes; then
- MARCO_PC_MODULES="$MARCO_PC_MODULES xcomposite >= $XCOMPOSITE_VERSION xfixes xrender xdamage"
+ MARCO_PC_MODULES="$MARCO_PC_MODULES xcomposite >= $XCOMPOSITE_VERSION xfixes xrender xdamage xres"
AC_DEFINE(HAVE_COMPOSITE_EXTENSIONS, 1, [Building with compositing manager support])
echo "Building with compositing manager"
diff --git a/meson.build b/meson.build
index e777b6c6..199baa77 100644
--- a/meson.build
+++ b/meson.build
@@ -153,12 +153,14 @@ gtk_req = '>= 3.22.0'
pango_req = '>= 1.2.0'
libcanberra_gtk_req = '>= 3.22.0'
startup_notification_req = '>= 0.7'
+xres_req = '>= 1.2.0'
glib_dep = dependency('glib-2.0', version: glib_req)
gtk_dep = dependency('gtk+-3.0', version: gtk_req)
gio_dep = dependency('gio-2.0', version: gio_req)
pango_dep = dependency('pango', version: pango_req)
libcanberra_gtk_dep = dependency('libcanberra-gtk3')
+xres_dep = dependency('xres', version: xres_req)
x11_dep = dependency('x11')
marco_deps = [
@@ -167,6 +169,7 @@ marco_deps = [
gio_dep,
pango_dep,
libcanberra_gtk_dep,
+ xres_dep,
]
marco_message_deps = [
diff --git a/src/core/window-props.c b/src/core/window-props.c
index fb8ac4c1..b5883ad1 100644
--- a/src/core/window-props.c
+++ b/src/core/window-props.c
@@ -47,6 +47,7 @@
#include "frame-private.h"
#include "group.h"
#include <X11/Xatom.h>
+#include <X11/extensions/XRes.h>
#include <unistd.h>
#include <string.h>
#include <errno.h>
@@ -294,11 +295,56 @@ reload_wm_window_role (MetaWindow *window,
meta_window_update_role (window);
}
+static pid_t
+get_local_pid (MetaWindow *window)
+{
+ pid_t pid;
+ XResClientIdSpec spec;
+ long num_ids;
+ XResClientIdValue *client_ids;
+ long i;
+
+ pid = -1;
+
+ spec.client = window->xwindow;
+ spec.mask = XRES_CLIENT_ID_PID_MASK;
+
+ XResQueryClientIds (window->display->xdisplay,
+ 1,
+ &spec,
+ &num_ids,
+ &client_ids);
+
+ for (i = 0; i < num_ids; i++)
+ {
+ if (client_ids[i].spec.mask == XRES_CLIENT_ID_PID_MASK)
+ {
+ pid = XResGetClientPid (&client_ids[i]);
+ break;
+ }
+ }
+
+ XResClientIdsDestroy (num_ids, client_ids);
+
+ return pid;
+}
+
static void
reload_net_wm_pid (MetaWindow *window,
MetaPropValue *value,
gboolean initial)
{
+ pid_t pid;
+
+ pid = get_local_pid (window);
+
+ if (pid != -1)
+ {
+ meta_verbose ("Using XResGetClientPid instead of _NET_WM_PID\n");
+
+ window->net_wm_pid = pid;
+ return;
+ }
if (value->type != META_PROP_VALUE_INVALID)
{
gulong cardinal = (int) value->v.cardinal;