summaryrefslogtreecommitdiff
path: root/src/backends/meta-logical-monitor.c
diff options
context:
space:
mode:
authorJonas Ådahl <jadahl@gmail.com>2017-03-27 23:45:28 +0800
committerJonas Ådahl <jadahl@gmail.com>2017-10-05 16:18:43 -0400
commit903537a2a0cb3ccf1f45dcdef4d9006fe191b51c (patch)
treed6c65bfc5739c652fa1aa3675da2957ccda809b4 /src/backends/meta-logical-monitor.c
parent1db937826ca6fde75652a36b107ce71e4475ed1c (diff)
downloadmutter-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.c45
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)
{