From 27e4d75edc0568170fd1f345e7c33b5175783b2a Mon Sep 17 00:00:00 2001 From: spixi Date: Wed, 8 Jan 2025 21:00:11 +0100 Subject: [PATCH] Add support for MATE Desktop (fixes #12169) --- .gitignore | 2 ++ common/Linux/LnxMisc.cpp | 17 +++++++++++++++-- 2 files changed, 17 insertions(+), 2 deletions(-) diff --git a/.gitignore b/.gitignore index b59e873da7838..fa8be8a7c1388 100644 --- a/.gitignore +++ b/.gitignore @@ -117,6 +117,8 @@ oprofile_data/ /out/build/x64-Debug (default) CMakeSettings.json +CMakeCache.txt +/CMakeFiles/ /ci-artifacts/ /out/ /.cache/ diff --git a/common/Linux/LnxMisc.cpp b/common/Linux/LnxMisc.cpp index 08423f622a379..b564adaf4979d 100644 --- a/common/Linux/LnxMisc.cpp +++ b/common/Linux/LnxMisc.cpp @@ -1,4 +1,4 @@ -// SPDX-FileCopyrightText: 2002-2024 PCSX2 Dev Team +// SPDX-FileCopyrightText: 2002-2025 PCSX2 Dev Team // SPDX-License-Identifier: GPL-3.0+ #include "common/Pcsx2Types.h" @@ -22,6 +22,8 @@ #include #include #include +#include +#include // Returns 0 on failure (not supported by the operating system). u64 GetPhysicalMemory() @@ -101,6 +103,7 @@ static bool SetScreensaverInhibitDBus(const bool inhibit_requested, const char* DBusMessage* message = nullptr; DBusMessage* response = nullptr; DBusMessageIter message_itr; + char* desktop_session = nullptr; ScopedGuard cleanup = [&]() { if (dbus_error_is_set(&error_dbus)) @@ -122,7 +125,17 @@ static bool SetScreensaverInhibitDBus(const bool inhibit_requested, const char* s_cookie = 0; s_comparison_connection = connection; } - message = dbus_message_new_method_call("org.freedesktop.ScreenSaver", "/org/freedesktop/ScreenSaver", "org.freedesktop.ScreenSaver", bus_method); + + desktop_session = std::getenv("DESKTOP_SESSION"); + if (desktop_session && std::strncmp(desktop_session, "mate", 4) == 0) + { + message = dbus_message_new_method_call("org.mate.ScreenSaver", "/org/mate/ScreenSaver", "org.mate.ScreenSaver", bus_method); + } + else + { + message = dbus_message_new_method_call("org.freedesktop.ScreenSaver", "/org/freedesktop/ScreenSaver", "org.freedesktop.ScreenSaver", bus_method); + } + if (!message) return false; // Initialize an append iterator for the message, gets freed with the message.