diff options
author | Jonas Ådahl <jadahl@gmail.com> | 2017-03-27 23:45:28 +0800 |
---|---|---|
committer | Jonas Ådahl <jadahl@gmail.com> | 2017-10-05 16:18:43 -0400 |
commit | 903537a2a0cb3ccf1f45dcdef4d9006fe191b51c (patch) | |
tree | d6c65bfc5739c652fa1aa3675da2957ccda809b4 /src/backends/meta-logical-monitor.c | |
parent | 1db937826ca6fde75652a36b107ce71e4475ed1c (diff) | |
download | mutter-903537a2a0cb3ccf1f45dcdef4d9006fe191b51c.tar.gz |
logical-monitor: Add helper for iterating over active CRTCs
Add meta_logical_monitor_foreach_crtc() helper to iterate over all the
active CRTCs driving the monitors associated with the specified logical
monitor.
https://bugzilla.gnome.org/show_bug.cgi?id=785381
Diffstat (limited to 'src/backends/meta-logical-monitor.c')
-rw-r--r-- | src/backends/meta-logical-monitor.c | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/src/backends/meta-logical-monitor.c b/src/backends/meta-logical-monitor.c index 2c1104482..0b688680e 100644 --- a/src/backends/meta-logical-monitor.c +++ b/src/backends/meta-logical-monitor.c @@ -201,6 +201,51 @@ meta_logical_monitor_get_monitors (MetaLogicalMonitor *logical_monitor) return logical_monitor->monitors; } +typedef struct _ForeachCrtcData +{ + MetaLogicalMonitor *logical_monitor; + MetaLogicalMonitorCrtcFunc func; + gpointer user_data; +} ForeachCrtcData; + +static gboolean +foreach_crtc (MetaMonitor *monitor, + MetaMonitorMode *mode, + MetaMonitorCrtcMode *monitor_crtc_mode, + gpointer user_data, + GError **error) +{ + ForeachCrtcData *data = user_data; + + data->func (data->logical_monitor, + monitor_crtc_mode->output->crtc, + data->user_data); + + return TRUE; +} + +void +meta_logical_monitor_foreach_crtc (MetaLogicalMonitor *logical_monitor, + MetaLogicalMonitorCrtcFunc func, + gpointer user_data) +{ + GList *l; + + for (l = logical_monitor->monitors; l; l = l->next) + { + MetaMonitor *monitor = l->data; + MetaMonitorMode *mode; + ForeachCrtcData data = { + .logical_monitor = logical_monitor, + .func = func, + .user_data = user_data + }; + + mode = meta_monitor_get_current_mode (monitor); + meta_monitor_mode_foreach_crtc (monitor, mode, foreach_crtc, &data, NULL); + } +} + static void meta_logical_monitor_init (MetaLogicalMonitor *logical_monitor) { |