diff options
author | Jonas Ã…dahl <jadahl@gmail.com> | 2021-04-19 15:22:57 +0200 |
---|---|---|
committer | Marge Bot <marge-bot@gnome.org> | 2021-05-18 13:19:36 +0000 |
commit | 18d670e69fbb484d7e6b5a243ecbe1483c74bdf5 (patch) | |
tree | b10aaf5271d273bb7c94615845d8da15e253d9a8 /src/backends/meta-idle-monitor.c | |
parent | 389432de46589cdbc2afb19a02feac69ecccfb15 (diff) | |
download | mutter-18d670e69fbb484d7e6b5a243ecbe1483c74bdf5.tar.gz |
backends: Introduce MetaIdleManager
This object takes over the functionality of meta-idle-monitor-dbus.c,
meta-idle-monitor.c and meta-backend.c, all related to higher level
management of idle watches etc.
The idle D-Bus API is changed to be initialized by the backend instead
of MetaDisplay, as it's more of a backend functionality than what
MetaDisplay usually deals with.
It also takes over the work of implementing "core" idle monitors. The
singleton API is replaced with thin wrapper functions on the backend.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/1859>
Diffstat (limited to 'src/backends/meta-idle-monitor.c')
-rw-r--r-- | src/backends/meta-idle-monitor.c | 49 |
1 files changed, 32 insertions, 17 deletions
diff --git a/src/backends/meta-idle-monitor.c b/src/backends/meta-idle-monitor.c index c678271cc..df924d4dd 100644 --- a/src/backends/meta-idle-monitor.c +++ b/src/backends/meta-idle-monitor.c @@ -35,7 +35,6 @@ #include "backends/gsm-inhibitor-flag.h" #include "backends/meta-backend-private.h" #include "backends/meta-idle-monitor-private.h" -#include "backends/meta-idle-monitor-dbus.h" #include "clutter/clutter.h" #include "meta/main.h" #include "meta/meta-idle-monitor.h" @@ -52,6 +51,18 @@ enum static GParamSpec *obj_props[PROP_LAST]; +struct _MetaIdleMonitor +{ + GObject parent; + + MetaIdleManager *idle_manager; + GDBusProxy *session_proxy; + gboolean inhibited; + GHashTable *watches; + ClutterInputDevice *device; + int64_t last_event_time; +}; + G_DEFINE_TYPE (MetaIdleMonitor, meta_idle_monitor, G_TYPE_OBJECT) static void @@ -266,22 +277,6 @@ meta_idle_monitor_init (MetaIdleMonitor *monitor) } } -/** - * meta_idle_monitor_get_core: - * - * Returns: (transfer none): the #MetaIdleMonitor that tracks the server-global - * idletime for all devices. - */ -MetaIdleMonitor * -meta_idle_monitor_get_core (void) -{ - MetaBackend *backend = meta_get_backend (); - ClutterBackend *clutter_backend = meta_backend_get_clutter_backend (backend); - ClutterSeat *seat = clutter_backend_get_default_seat (clutter_backend); - - return meta_backend_get_idle_monitor (backend, clutter_seat_get_pointer (seat)); -} - static guint32 get_next_watch_serial (void) { @@ -513,3 +508,23 @@ meta_idle_monitor_reset_idletime (MetaIdleMonitor *monitor) g_list_free (watch_ids); } + +MetaIdleManager * +meta_idle_monitor_get_manager (MetaIdleMonitor *monitor) +{ + return monitor->idle_manager; +} + +MetaIdleMonitor * +meta_idle_monitor_new (MetaIdleManager *idle_manager, + ClutterInputDevice *device) +{ + MetaIdleMonitor *monitor; + + monitor = g_object_new (META_TYPE_IDLE_MONITOR, + "device", device, + NULL); + monitor->idle_manager = idle_manager; + + return monitor; +} |