<AWT Dev> [7u10] Review request for 6981400 Tabbing between textfield do not work properly when ALT+TAB

Leonid Romanov leonid.romanov at oracle.com
Fri Sep 7 08:20:57 PDT 2012


Looks good.


On Sep 7, 2012, at 1:57 PM, "Anton V. Tarasov" <anton.tarasov at oracle.com> wrote:

> Hi,
> 
> Please review a fix for the CR:
> 
> http://bugs.sun.com/bugdatabase/view_bug.do?bug_id=6981400
> 
> Webrev:
> 
> http://cr.openjdk.java.net/~ant/6981400.7u10/webrev.0/
> 
> It's almost identical to the fix pushed to jdk8 recently. The only small difference is here:
> 
> http://cr.openjdk.java.net/~ant/6981400.7u10/webrev.0/src/macosx/classes/sun/lwawt/LWWindowPeer.java.sdiff.html
> 
> In the dispatchKeyEvent method, LWKeyboardFocusManagerPeer is retrieved by passing an AppContext instance.
> In jdk8 LWKeyboardFocusManagerPeer was refactored (CR 7124375).
> 
> Below I'm quoting the description of the fix for jdk8:
> 
> <<The fix covers a number of issues and is an evaluated version of the fix originally integrated into jdk6. The scenario which reproduces
> the referred problems looks pretty like the following:
> 
> A frame with components. The first component is focused. In its focusLost(..) listener it performs some lengthy operation.
> TAB key is pressed, say, 5 times. The first component loses focus, the lengthy operation begins which freezes EDT for a while.
> At the same time, a user switches to some other window by Alt-TAB  and then switches back by another Alt-TAB. When the lengthy
> operation is done, the user expects focus to be transferred through the components in order as if no toplevel switch has happened.
> Alternatively, the toplevel switch could be done by a mouse click in a component of the other java toplevel and then by a click to the
> title of the original frame.
> 
> This may cause the following unexpected results:
> 
> 1) Focus doesn't go through all the 5 components (which 5 TABs should result in) but stops on, say, the 3rd one.
> 2) Components are being transferred in wrong order, say 2, 3, 2, 4, 5, 6 instead of 2, 3, 4, 5, 6. 
> 3) A menu of the original frame eventually gets activated (reproducible on MS Windows).>>
> 
> More details can be found here:
> 
> http://mail.openjdk.java.net/pipermail/awt-dev/2012-August/003421.html
> 
> Thanks,
> Anton.




More information about the awt-dev mailing list