WebKit Bugzilla
New
Browse
Log In
×
Sign in with GitHub
or
Remember my login
Create Account
·
Forgot Password
Forgotten password account recovery
RESOLVED FIXED
200559
Accessibility client cannot navigate to internal links targets on iOS.
https://bugs.webkit.org/show_bug.cgi?id=200559
Summary
Accessibility client cannot navigate to internal links targets on iOS.
Andres Gonzalez
Reported
2019-08-08 19:46:52 PDT
Accessibility client cannot navigate to internal links targets on iOS.
Attachments
Patch
(9.25 KB, patch)
2019-08-08 20:04 PDT
,
Andres Gonzalez
no flags
Details
Formatted Diff
Diff
Patch
(9.31 KB, patch)
2019-08-09 13:09 PDT
,
Andres Gonzalez
no flags
Details
Formatted Diff
Diff
Show Obsolete
(1)
View All
Add attachment
proposed patch, testcase, etc.
Andres Gonzalez
Comment 1
2019-08-08 20:04:49 PDT
Created
attachment 375884
[details]
Patch
Darin Adler
Comment 2
2019-08-09 09:46:02 PDT
Comment on
attachment 375884
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=375884&action=review
Looks good.
> Source/WebCore/accessibility/AccessibilityObject.cpp:545 > + return WebCore::firstAccessibleObjectFromNode(node, [] (const AccessibilityObject& acc) { > + return !acc.accessibilityIsIgnored(); > + });
WebKit coding style says we should use words, not abbreviations, for variable names. So the name here could be "object", "accessibilityObject", "candidate", or some other word, but shouldn’t be "acc".
> Source/WebCore/accessibility/ios/WebAccessibilityObjectWrapperIOS.mm:1816 > + /* AccessibilityObject::linkedUIElements may return an object that is > + exposed in other platforms but not on iOS, i.e., grouping or structure > + elements like <div> or <p>. Thus find the next accessible object that is > + exposed on iOS. > + */
WebKit coding style calls for "//" comments, not "/*" comments.
> Source/WebCore/accessibility/ios/WebAccessibilityObjectWrapperIOS.mm:1820 > + if (auto linked = firstAccessibleObjectFromNode(linkedElements[0]->node(), [] (const AccessibilityObject& acc) { > + return acc.wrapper().isAccessibilityElement; > + })) > + return linked->wrapper();
Same issue with variable named "acc". Formatting here makes this hard to read. Might want to rearrange to avoid that. One way to do it is: auto linkedElement = firstAccessibleObjectFromNode(linkedElements[0]->node(), [] (const AccessibilityObject& object) { return object.wrapper().isAccessibilityElement; }); return linkedElement ? linkedElement->wrapper() : nullptr; But I’m sure there are other ways to sidestep it too.
Andres Gonzalez
Comment 3
2019-08-09 13:09:25 PDT
Created
attachment 375944
[details]
Patch
Andres Gonzalez
Comment 4
2019-08-09 13:20:18 PDT
(In reply to Darin Adler from
comment #2
)
> Comment on
attachment 375884
[details]
> Patch > > View in context: >
https://bugs.webkit.org/attachment.cgi?id=375884&action=review
> > Looks good. >
Thanks very much Darin, for the prompt review and good points.
> > Source/WebCore/accessibility/AccessibilityObject.cpp:545 > > + return WebCore::firstAccessibleObjectFromNode(node, [] (const AccessibilityObject& acc) { > > + return !acc.accessibilityIsIgnored(); > > + }); > > WebKit coding style says we should use words, not abbreviations, for > variable names. So the name here could be "object", "accessibilityObject", > "candidate", or some other word, but shouldn’t be "acc". >
Changed it too accessible.
> > Source/WebCore/accessibility/ios/WebAccessibilityObjectWrapperIOS.mm:1816 > > + /* AccessibilityObject::linkedUIElements may return an object that is > > + exposed in other platforms but not on iOS, i.e., grouping or structure > > + elements like <div> or <p>. Thus find the next accessible object that is > > + exposed on iOS. > > + */ > > WebKit coding style calls for "//" comments, not "/*" comments. >
Changed it to // comment. I personally prefer /* */ for multiline comments, so that I don't have to hear "slash slash" before every line of text. But I will of course adhere to the WebKit coding style conventions.
> > Source/WebCore/accessibility/ios/WebAccessibilityObjectWrapperIOS.mm:1820 > > + if (auto linked = firstAccessibleObjectFromNode(linkedElements[0]->node(), [] (const AccessibilityObject& acc) { > > + return acc.wrapper().isAccessibilityElement; > > + })) > > + return linked->wrapper(); > > Same issue with variable named "acc". > > Formatting here makes this hard to read. Might want to rearrange to avoid > that. One way to do it is: > > auto linkedElement = > firstAccessibleObjectFromNode(linkedElements[0]->node(), [] (const > AccessibilityObject& object) { > return object.wrapper().isAccessibilityElement; > }); > return linkedElement ? linkedElement->wrapper() : nullptr; > > But I’m sure there are other ways to sidestep it too.
Thanks! agree this way is much more legible. Done.
WebKit Commit Bot
Comment 5
2019-08-10 20:46:16 PDT
Comment on
attachment 375944
[details]
Patch Clearing flags on attachment: 375944 Committed
r248513
: <
https://trac.webkit.org/changeset/248513
>
WebKit Commit Bot
Comment 6
2019-08-10 20:46:17 PDT
All reviewed patches have been landed. Closing bug.
Radar WebKit Bug Importer
Comment 7
2019-08-10 20:47:16 PDT
<
rdar://problem/54173330
>
Note
You need to
log in
before you can comment on or make changes to this bug.
Top of Page
Format For Printing
XML
Clone This Bug