7124537: [macosx] Menu shortcuts for all menu items should be disabled if a menu itself is disabled
Reviewed-by: anthony, leonidr
This commit is contained in:
parent
fcb6d58798
commit
d8c5dcc1fc
@ -26,9 +26,11 @@
|
||||
package sun.lwawt.macosx;
|
||||
|
||||
import java.awt.*;
|
||||
import java.awt.peer.MenuItemPeer;
|
||||
import java.awt.peer.MenuPeer;
|
||||
|
||||
public class CMenu extends CMenuItem implements MenuPeer {
|
||||
|
||||
public CMenu(Menu target) {
|
||||
super(target);
|
||||
}
|
||||
@ -40,6 +42,20 @@ public class CMenu extends CMenuItem implements MenuPeer {
|
||||
setEnabled(target.isEnabled());
|
||||
}
|
||||
|
||||
@Override
|
||||
public final void setEnabled(final boolean b) {
|
||||
super.setEnabled(b);
|
||||
final Menu target = (Menu) getTarget();
|
||||
final int count = target.getItemCount();
|
||||
for (int i = 0; i < count; ++i) {
|
||||
MenuItem item = target.getItem(i);
|
||||
MenuItemPeer p = (MenuItemPeer) LWCToolkit.targetToPeer(item);
|
||||
if (p != null) {
|
||||
p.setEnabled(b && item.isEnabled());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
protected long createModel() {
|
||||
CMenuComponent parent = (CMenuComponent)
|
||||
|
@ -28,17 +28,20 @@ package sun.lwawt.macosx;
|
||||
import sun.awt.SunToolkit;
|
||||
import sun.lwawt.LWToolkit;
|
||||
|
||||
import java.awt.MenuContainer;
|
||||
import java.awt.MenuItem;
|
||||
import java.awt.MenuShortcut;
|
||||
import java.awt.event.*;
|
||||
import java.awt.peer.MenuItemPeer;
|
||||
import java.util.concurrent.atomic.AtomicBoolean;
|
||||
|
||||
public class CMenuItem extends CMenuComponent implements MenuItemPeer {
|
||||
|
||||
private final AtomicBoolean enabled = new AtomicBoolean(true);
|
||||
|
||||
public CMenuItem(MenuItem target) {
|
||||
super(target);
|
||||
initialize(target);
|
||||
|
||||
}
|
||||
|
||||
// This way we avoiding invocation of the setters twice
|
||||
@ -124,10 +127,20 @@ public class CMenuItem extends CMenuComponent implements MenuItemPeer {
|
||||
setEnabled(false);
|
||||
}
|
||||
|
||||
public final boolean isEnabled() {
|
||||
return enabled.get();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setEnabled(boolean b) {
|
||||
final Object parent = LWToolkit.targetToPeer(getTarget().getParent());
|
||||
if (parent instanceof CMenuItem) {
|
||||
b &= ((CMenuItem) parent).isEnabled();
|
||||
}
|
||||
if (enabled.compareAndSet(!b, b)) {
|
||||
nativeSetEnabled(getModel(), b);
|
||||
}
|
||||
}
|
||||
|
||||
private native long nativeCreate(long parentMenu, boolean isSeparator);
|
||||
private native void nativeSetLabel(long modelPtr, String label, char keyChar, int keyCode, int modifiers);
|
||||
|
Loading…
Reference in New Issue
Block a user