<html>
    <head>
      <base href="https://bugs.webkit.org/" />
    </head>
    <body><span class="vcard"><a class="email" href="mailto:darin&#64;apple.com" title="Darin Adler &lt;darin&#64;apple.com&gt;"> <span class="fn">Darin Adler</span></a>
</span> changed
              <a class="bz_bug_link 
          bz_status_NEW "
   title="NEW - AX: richer text change notifications"
   href="https://bugs.webkit.org/show_bug.cgi?id=142719">bug 142719</a>
        <br>
             <table border="1" cellspacing="0" cellpadding="8">
          <tr>
            <th>What</th>
            <th>Removed</th>
            <th>Added</th>
          </tr>

         <tr>
           <td style="text-align:right;">Attachment #251203 Flags</td>
           <td>review?
           </td>
           <td>
               &nbsp;
           </td>
         </tr></table>
      <p>
        <div>
            <b><a class="bz_bug_link 
          bz_status_NEW "
   title="NEW - AX: richer text change notifications"
   href="https://bugs.webkit.org/show_bug.cgi?id=142719#c93">Comment # 93</a>
              on <a class="bz_bug_link 
          bz_status_NEW "
   title="NEW - AX: richer text change notifications"
   href="https://bugs.webkit.org/show_bug.cgi?id=142719">bug 142719</a>
              from <span class="vcard"><a class="email" href="mailto:darin&#64;apple.com" title="Darin Adler &lt;darin&#64;apple.com&gt;"> <span class="fn">Darin Adler</span></a>
</span></b>
        <pre>Comment on <span class=""><a href="attachment.cgi?id=251203&amp;action=diff" name="attach_251203" title="Update from review">attachment 251203</a> <a href="attachment.cgi?id=251203&amp;action=edit" title="Update from review">[details]</a></span>
Update from review

View in context: <a href="https://bugs.webkit.org/attachment.cgi?id=251203&amp;action=review">https://bugs.webkit.org/attachment.cgi?id=251203&amp;action=review</a>

I started reviewing but I didn’t get to the end yet.

Generally this patch is messing up the editing machinery with way too much explicit accessibility-specific code and should be done more elegantly if possible.

<span class="quote">&gt; Source/WebCore/ChangeLog:210
&gt; +2015-04-17  Doug Russell  &lt;<a href="mailto:d_russell&#64;apple.com">d_russell&#64;apple.com</a>&gt;
&gt; +
&gt; +        AX: richer text change notifications
&gt; +        <a class="bz_bug_link 
          bz_status_NEW "
   title="NEW - AX: richer text change notifications"
   href="show_bug.cgi?id=142719">https://bugs.webkit.org/show_bug.cgi?id=142719</a>
&gt; +
&gt; +        Richer accessibility selection change notifications. Introduce AXTextStateChangeIntent, and an overload of postTextReplacementNotification to give assistive tech apps more reliable context for responding to changes in web content selection. Also block posting selection changes on password fields.
&gt; +
&gt; +2015-04-14  Doug Russell  &lt;<a href="mailto:d_russell&#64;apple.com">d_russell&#64;apple.com</a>&gt;
&gt; +
&gt; +        AX: richer text change notifications
&gt; +        <a class="bz_bug_link 
          bz_status_NEW "
   title="NEW - AX: richer text change notifications"
   href="show_bug.cgi?id=142719">https://bugs.webkit.org/show_bug.cgi?id=142719</a>
&gt; +
&gt; +        Richer accessibility value change notifications. Introduce AXTextEditType, postTextStateChangeNotification and postTextReplacementNotification to give assistive tech apps more reliable context for responding to changes in web content. Also implement a mechanism to post value changes in password form fields in coalesced ticks to thwart analyzing the cadence of changes.
&gt; +
&gt; +2015-04-14  Doug Russell  &lt;<a href="mailto:d_russell&#64;apple.com">d_russell&#64;apple.com</a>&gt;
&gt; +
&gt; +        AX: richer text change notifications
&gt; +        <a class="bz_bug_link 
          bz_status_NEW "
   title="NEW - AX: richer text change notifications"
   href="show_bug.cgi?id=142719">https://bugs.webkit.org/show_bug.cgi?id=142719</a>
&gt; +
&gt; +        New EditCommand subclasses to give the context that accessibility needs to post more detailed value and selection change notifications. This commit is all infrastructure and doesn't contain any accessibility specific changes.
&gt; +</span >

Need to remove these extra change log entries.

<span class="quote">&gt; Source/WebCore/accessibility/AXObjectCache.cpp:1319
&gt; +    if (!rootObject)
&gt; +        return nullptr;
&gt; +    if (rootObject-&gt;isAccessibilityScrollView())
&gt; +        return downcast&lt;AccessibilityScrollView&gt;(*rootObject).webAreaObject();
&gt; +    return nullptr;</span >

Slightly nicer to stick 100% with the early return style so the real code is on the left, not nested. I’d write it like this:

    if (!rootObject || !rootObject-&gt;isAccessibiltyScrollView())
        return nullptr;
    return downcast&lt;AccessibilityScrollView&gt;(*rootObject).webAreaObject();

<span class="quote">&gt; Source/WebCore/accessibility/AXObjectCache.h:199
&gt; +    // Simple text value change</span >

I don’t think this comment adds much.

<span class="quote">&gt; Source/WebCore/accessibility/AXObjectCache.h:201
&gt; +    // Compound text value change</span >

I don’t think this comment adds much.

<span class="quote">&gt; Source/WebCore/accessibility/AXObjectCache.h:203
&gt; +    // Selection change</span >

I don’t think this comment adds much.

<span class="quote">&gt; Source/WebCore/accessibility/AXObjectCache.h:224
&gt; +#if PLATFORM(COCOA) &amp;&amp; !PLATFORM(IOS)</span >

Should instead be:

    #if PLATFORM(MAC)

<span class="quote">&gt; Source/WebCore/accessibility/AXObjectCache.h:257
&gt; +    AXTextChange textChangeForEditType(AXTextEditType type)
&gt; +    {
&gt; +        switch (type) {
&gt; +        case AXTextEditTypeCut:
&gt; +        case AXTextEditTypeDelete:
&gt; +            return AXTextDeleted;
&gt; +        case AXTextEditTypeInsert:
&gt; +        case AXTextEditTypeDictation:
&gt; +        case AXTextEditTypeTyping:
&gt; +        case AXTextEditTypePaste:
&gt; +            return AXTextInserted;
&gt; +        default:
&gt; +            break;
&gt; +        }
&gt; +        ASSERT_NOT_REACHED();
&gt; +        return AXTextInserted;
&gt; +    }</span >

Why does this function have to be here in the header? I suggest declaring the function here, but defining it in the cpp file. Or we could define it later in this file. Putting the entire definition in the class makes the class unnecessarily hard to read. Also, this should be a static member function, not a member function. The &quot;default: break;” code should be omitted. Including a default case causes the compiler to turn off its checking that the switch statement covers all enum values.

<span class="quote">&gt; Source/WebCore/accessibility/AccessibilityNodeObject.cpp:563
&gt; +            return const_cast&lt;AccessibilityNodeObject*&gt;(this);</span >

No need for this const_cast.

<span class="quote">&gt; Source/WebCore/accessibility/AccessibilityNodeObject.cpp:567
&gt; +    if (!is&lt;HTMLInputElement&gt;(*element))</span >

Need to remove the * here, in case node-&gt;shadowHost() is null. The is function will handle null, but only if passed a pointer rather than a reference.

<span class="quote">&gt; Source/WebCore/accessibility/AccessibilityNodeObject.cpp:571
&gt; +    if (AXObjectCache* cache = axObjectCache())
&gt; +        return cache-&gt;getOrCreate(element);</span >

Missing a null check for element here, I think.

<span class="quote">&gt; Source/WebCore/accessibility/mac/AXObjectCacheMac.mm:92
&gt; +static NSUInteger const NSAccessibilityValueChangeTruncationLength = 1000;</span >

We normally put the &quot;const&quot; before the type in declarations like this one.

It’s not appropriate to define something here with an NS prefix; that’s reserved for AppKit, and WebKit shouldn’t use that prefix for its own internal constants.

<span class="quote">&gt; Source/WebCore/accessibility/mac/AXObjectCacheMac.mm:111
&gt; +void AXObjectCache::setShouldRepostNotificationsForTests(bool value)</span >

Missing blank lines between functions here.

<span class="quote">&gt; Source/WebCore/editing/CompositeEditCommand.cpp:332
&gt; +static void setCommandApplyEditTypeForEditingAction(SimpleEditCommand *command, EditAction editingAction)</span >

Incorrect formatting of SimpleEditCommand* here.

<span class="quote">&gt; Source/WebCore/editing/CutDeleteSelectionCommand.h:43
&gt; +    virtual EditAction editingAction() const override;</span >

Do we really need an entire new DeleteSelectionCommand subclass just to customize the editing action? Instead we should just have a new create function in DeleteSelectionCommand and have it store a flag to record the fact that it’s for a cut.

<span class="quote">&gt; Source/WebCore/editing/DeleteFromTextNodeCommand.h:29
&gt; +#include &quot;AXObjectCache.h&quot;</span >

Doesn’t make sense to add this include. Why is it needed?

<span class="quote">&gt; Source/WebCore/editing/DeleteFromTextNodeCommand.h:43
&gt; +    String&amp; deletedText();</span >

This seems wrong. We don’t want to expose the deleted text as a non-const reference. We don’t want to allow someone to change this underneath us.

<span class="quote">&gt; Source/WebCore/editing/DeleteFromTextNodeCommand.h:49
&gt; +</span >

Please don’t add this blank line here.

<span class="quote">&gt; Source/WebCore/editing/DictationInsertTextCommand.h:43
&gt; +    virtual EditAction editingAction() const override;</span >

Same comment. Don’t create an entire new derived class just to customize the editing action. Just add a new create function and a data member instead.

<span class="quote">&gt; Source/WebCore/editing/EditCommand.h:29
&gt; +#include &quot;AXObjectCache.h&quot;</span >

Can we instead include only the header that defines the types, not the entire AXObjectCache.h header?

<span class="quote">&gt; Source/WebCore/editing/Editor.cpp:386
&gt; +    if (editingAction == EditActionCut)
&gt; +        applyCommand(CutDeleteSelectionCommand::create(document(), smartDelete));
&gt; +    else
&gt; +        applyCommand(DeleteSelectionCommand::create(document(), smartDelete));</span >

Clearly we should just pass in the editingAction here instead of having two completely separate classes!

<span class="quote">&gt; Source/WebCore/editing/Editor.cpp:1008
&gt; +    changeSelectionAfterCommand(newSelection, options, AXTextStateChangeIntent(cmd-&gt;applyEditType()));</span >

Should just be able to pass cmd-&gt;applyEditType() here. Should not need an explicit conversion to AXTextStateChangeIntent, because the constructor is not marked explicit.

<span class="quote">&gt; Source/WebCore/editing/Editor.cpp:1039
&gt; +    changeSelectionAfterCommand(newSelection, FrameSelection::defaultSetSelectionOptions(), AXTextStateChangeIntent(cmd-&gt;unapplyEditType()));</span >

Should just be able to pass cmd-&gt;applyEditType() here. Should not need an explicit conversion to AXTextStateChangeIntent, because the constructor is not marked explicit.

<span class="quote">&gt; Source/WebCore/editing/Editor.h:177
&gt; +    WEBCORE_EXPORT void deleteSelectionWithSmartDelete(bool smartDelete, EditAction editingAction = EditActionDelete);</span >

Should omit the argument name editingAction here.

<span class="quote">&gt; Source/WebCore/editing/EditorCommand.cpp:196
&gt; +    command-&gt;setApplyEditType(AXTextEditTypeInsert);</span >

Should add this as a constructor argument, not require a separate set function after the fact for this.

<span class="quote">&gt; Source/WebCore/editing/FrameSelection.cpp:261
&gt; +    if (AXObjectCache::accessibilityEnabled()) {
&gt; +        if (newSelection.isCaret())</span >

Should just use &amp;&amp; here.

<span class="quote">&gt; Source/WebCore/editing/FrameSelection.cpp:266
&gt; +        else
&gt; +            intent = AXTextStateChangeIntent();
&gt; +    } else
&gt; +        intent = AXTextStateChangeIntent();</span >

This code isn’t needed. The variable intent has already been initialized and there’s no need to set it again.

<span class="quote">&gt; Source/WebCore/editing/FrameSelection.cpp:1046
&gt; +        if (isRange()) {
&gt; +            if (directionOfSelection() == RTL)
&gt; +                flip = true;
&gt; +        }</span >

Reads better as:

    flip = isRange() &amp;&amp; directionOfSelection() == RTL;

<span class="quote">&gt; Source/WebCore/editing/FrameSelection.h:136
&gt; +    static inline AXTextStateChangeIntent defaultSetSelectionIntent()</span >

The inline keyword here is not needed and not helpful. Also seems overkill to write a function for this since the default is the default value for the class.

<span class="quote">&gt; Source/WebCore/editing/InsertIntoTextNodeCommand.h:29
&gt; +#include &quot;AXObjectCache.h&quot;</span >

Should not add this include.

<span class="quote">&gt; Source/WebCore/editing/InsertIntoTextNodeCommand.h:43
&gt; +    String&amp; insertedText();</span >

Same problem as above. No reason to expose a non-const reference to internal state.</pre>
        </div>
      </p>
      <hr>
      <span>You are receiving this mail because:</span>
      
      <ul>
          <li>You are the assignee for the bug.</li>
      </ul>
    </body>
</html>