From: Lukáš Tyrychtr Date: Fri, 9 Sep 2022 15:02:34 +0000 (+0200) Subject: a11y: Skip non-presentable objects X-Git-Tag: archive/raspbian/4.12.3+ds-1+rpi1~1^2^2^2~22^2~8^2~9^2~17 X-Git-Url: https://dgit.raspbian.org/?a=commitdiff_plain;h=a80af681b840e123743eaba00ff2a23845301d6c;p=gtk4.git a11y: Skip non-presentable objects Don't get confused with non-presentable objects when iterating the list of children. --- diff --git a/gtk/a11y/gtkatspicontext.c b/gtk/a11y/gtkatspicontext.c index 034dbdc05a..adddbd5851 100644 --- a/gtk/a11y/gtkatspicontext.c +++ b/gtk/a11y/gtkatspicontext.c @@ -332,24 +332,27 @@ static int get_index_in (GtkAccessible *parent, GtkAccessible *child) { GtkAccessible *candidate; + int res; int idx; if (parent == NULL) return -1; idx = 0; + res = 0; while (true) { candidate = gtk_accessible_get_child_at_index (parent, idx); if (!candidate) break; if (candidate == child) - return idx; + return res; + idx++; if (!gtk_accessible_should_present (candidate)) continue; - idx++; + res++; } return -1; @@ -489,7 +492,7 @@ handle_accessible_method (GDBusConnection *connection, { GtkATContext *context = NULL; GtkAccessible *accessible; - int idx, real_idx = 0; + int idx, presentable_idx, child_idx; g_variant_get (parameters, "(i)", &idx); @@ -497,17 +500,19 @@ handle_accessible_method (GDBusConnection *connection, GtkAccessible *child; - real_idx = 0; + presentable_idx = 0; + child_idx = 0; do { - child = gtk_accessible_get_child_at_index (accessible, real_idx); + child = gtk_accessible_get_child_at_index (accessible, child_idx); + child_idx += 1; if (!gtk_accessible_should_present (child)) continue; - if (real_idx == idx) + if (presentable_idx == idx) break; + presentable_idx++; - real_idx += 1; } while (child != NULL); @@ -1718,15 +1723,16 @@ gtk_at_spi_context_get_child_count (GtkAtSpiContext *self) GtkAccessible *accessible = gtk_at_context_get_accessible (GTK_AT_CONTEXT (self)); int n_children = 0; + int idx = 0; GtkAccessible *child; - while (true) { - child = gtk_accessible_get_child_at_index (accessible, n_children); + child = gtk_accessible_get_child_at_index (accessible, idx); if (!child) break; + idx++; if (!gtk_accessible_should_present (child)) continue;