mirror of
				https://github.com/yuzu-emu/yuzu-android
				synced 2025-10-24 19:50:29 -07:00 
			
		
		
		
	Qt: enable recent Linux features on more Unices
- Prevent sleep via xdg-desktop-portal afterfa7abafa5f- Pause on suspend afterb7642cff36- Exit on SIGINT/SIGTERM after9479940a1f- Improve dark themes afterb51db12567
This commit is contained in:
		| @@ -315,7 +315,7 @@ target_include_directories(yuzu PRIVATE ../../externals/Vulkan-Headers/include) | ||||
| if (NOT WIN32) | ||||
|     target_include_directories(yuzu PRIVATE ${Qt5Gui_PRIVATE_INCLUDE_DIRS}) | ||||
| endif() | ||||
| if (${CMAKE_SYSTEM_NAME} STREQUAL "Linux") | ||||
| if (UNIX AND NOT APPLE) | ||||
|     target_link_libraries(yuzu PRIVATE Qt::DBus) | ||||
| endif() | ||||
|  | ||||
|   | ||||
| @@ -9,7 +9,7 @@ | ||||
| #ifdef __APPLE__ | ||||
| #include <unistd.h> // for chdir | ||||
| #endif | ||||
| #ifdef __linux__ | ||||
| #ifdef __unix__ | ||||
| #include <csignal> | ||||
| #include <sys/socket.h> | ||||
| #endif | ||||
| @@ -275,7 +275,7 @@ static void OverrideWindowsFont() { | ||||
| #endif | ||||
|  | ||||
| bool GMainWindow::CheckDarkMode() { | ||||
| #ifdef __linux__ | ||||
| #ifdef __unix__ | ||||
|     const QPalette test_palette(qApp->palette()); | ||||
|     const QColor text_color = test_palette.color(QPalette::Active, QPalette::Text); | ||||
|     const QColor window_color = test_palette.color(QPalette::Active, QPalette::Window); | ||||
| @@ -283,7 +283,7 @@ bool GMainWindow::CheckDarkMode() { | ||||
| #else | ||||
|     // TODO: Windows | ||||
|     return false; | ||||
| #endif // __linux__ | ||||
| #endif // __unix__ | ||||
| } | ||||
|  | ||||
| GMainWindow::GMainWindow(std::unique_ptr<Config> config_, bool has_broken_vulkan) | ||||
| @@ -291,7 +291,7 @@ GMainWindow::GMainWindow(std::unique_ptr<Config> config_, bool has_broken_vulkan | ||||
|       input_subsystem{std::make_shared<InputCommon::InputSubsystem>()}, config{std::move(config_)}, | ||||
|       vfs{std::make_shared<FileSys::RealVfsFilesystem>()}, | ||||
|       provider{std::make_unique<FileSys::ManualContentProvider>()} { | ||||
| #ifdef __linux__ | ||||
| #ifdef __unix__ | ||||
|     SetupSigInterrupts(); | ||||
| #endif | ||||
|     system->Initialize(); | ||||
| @@ -509,7 +509,7 @@ GMainWindow::~GMainWindow() { | ||||
|         delete render_window; | ||||
|     } | ||||
|  | ||||
| #ifdef __linux__ | ||||
| #ifdef __unix__ | ||||
|     ::close(sig_interrupt_fds[0]); | ||||
|     ::close(sig_interrupt_fds[1]); | ||||
| #endif | ||||
| @@ -1379,7 +1379,7 @@ void GMainWindow::OnDisplayTitleBars(bool show) { | ||||
| } | ||||
|  | ||||
| void GMainWindow::SetupPrepareForSleep() { | ||||
| #ifdef __linux__ | ||||
| #ifdef __unix__ | ||||
|     auto bus = QDBusConnection::systemBus(); | ||||
|     if (bus.isConnected()) { | ||||
|         const bool success = bus.connect( | ||||
| @@ -1393,7 +1393,7 @@ void GMainWindow::SetupPrepareForSleep() { | ||||
|     } else { | ||||
|         LOG_WARNING(Frontend, "QDBusConnection system bus is not connected"); | ||||
|     } | ||||
| #endif // __linux__ | ||||
| #endif // __unix__ | ||||
| } | ||||
|  | ||||
| void GMainWindow::OnPrepareForSleep(bool prepare_sleep) { | ||||
| @@ -1415,7 +1415,7 @@ void GMainWindow::OnPrepareForSleep(bool prepare_sleep) { | ||||
|     } | ||||
| } | ||||
|  | ||||
| #ifdef __linux__ | ||||
| #ifdef __unix__ | ||||
| static std::optional<QDBusObjectPath> HoldWakeLockLinux(u32 window_id = 0) { | ||||
|     if (!QDBusConnection::sessionBus().isConnected()) { | ||||
|         return {}; | ||||
| @@ -1500,14 +1500,14 @@ void GMainWindow::OnSigInterruptNotifierActivated() { | ||||
|  | ||||
|     emit SigInterrupt(); | ||||
| } | ||||
| #endif // __linux__ | ||||
| #endif // __unix__ | ||||
|  | ||||
| void GMainWindow::PreventOSSleep() { | ||||
| #ifdef _WIN32 | ||||
|     SetThreadExecutionState(ES_CONTINUOUS | ES_SYSTEM_REQUIRED | ES_DISPLAY_REQUIRED); | ||||
| #elif defined(HAVE_SDL2) | ||||
|     SDL_DisableScreenSaver(); | ||||
| #ifdef __linux__ | ||||
| #ifdef __unix__ | ||||
|     auto reply = HoldWakeLockLinux(winId()); | ||||
|     if (reply) { | ||||
|         wake_lock = std::move(reply.value()); | ||||
| @@ -1521,7 +1521,7 @@ void GMainWindow::AllowOSSleep() { | ||||
|     SetThreadExecutionState(ES_CONTINUOUS); | ||||
| #elif defined(HAVE_SDL2) | ||||
|     SDL_EnableScreenSaver(); | ||||
| #ifdef __linux__ | ||||
| #ifdef __unix__ | ||||
|     if (!wake_lock.path().isEmpty()) { | ||||
|         ReleaseWakeLockLinux(wake_lock); | ||||
|     } | ||||
| @@ -4070,7 +4070,7 @@ void GMainWindow::SetDiscordEnabled([[maybe_unused]] bool state) { | ||||
| } | ||||
|  | ||||
| void GMainWindow::changeEvent(QEvent* event) { | ||||
| #ifdef __linux__ | ||||
| #ifdef __unix__ | ||||
|     // PaletteChange event appears to only reach so far into the GUI, explicitly asking to | ||||
|     // UpdateUITheme is a decent work around | ||||
|     if (event->type() == QEvent::PaletteChange) { | ||||
| @@ -4085,7 +4085,7 @@ void GMainWindow::changeEvent(QEvent* event) { | ||||
|         } | ||||
|         last_window_color = window_color; | ||||
|     } | ||||
| #endif // __linux__ | ||||
| #endif // __unix__ | ||||
|     QWidget::changeEvent(event); | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -15,7 +15,7 @@ | ||||
| #include "yuzu/compatibility_list.h" | ||||
| #include "yuzu/hotkeys.h" | ||||
|  | ||||
| #ifdef __linux__ | ||||
| #ifdef __unix__ | ||||
| #include <QVariant> | ||||
| #include <QtDBus/QDBusInterface> | ||||
| #include <QtDBus/QtDBus> | ||||
| @@ -255,7 +255,7 @@ private: | ||||
|     void changeEvent(QEvent* event) override; | ||||
|     void closeEvent(QCloseEvent* event) override; | ||||
|  | ||||
| #ifdef __linux__ | ||||
| #ifdef __unix__ | ||||
|     void SetupSigInterrupts(); | ||||
|     static void HandleSigInterrupt(int); | ||||
|     void OnSigInterruptNotifierActivated(); | ||||
| @@ -435,7 +435,7 @@ private: | ||||
|     // True if TAS recording dialog is visible | ||||
|     bool is_tas_recording_dialog_active{}; | ||||
|  | ||||
| #ifdef __linux__ | ||||
| #ifdef __unix__ | ||||
|     QSocketNotifier* sig_interrupt_notifier; | ||||
|     static std::array<int, 3> sig_interrupt_fds; | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user