提交 33a6e77f 编写于 作者: S serb

7097771: setEnabled does not work for components in disabled containers.

Reviewed-by: art, anthony
上级 049b650b
...@@ -82,7 +82,7 @@ public class XComponentPeer extends XWindow implements ComponentPeer, DropTarget ...@@ -82,7 +82,7 @@ public class XComponentPeer extends XWindow implements ComponentPeer, DropTarget
boolean paintPending = false; boolean paintPending = false;
boolean isLayouting = false; boolean isLayouting = false;
boolean enabled; private boolean enabled;
// Actually used only by XDecoratedPeer // Actually used only by XDecoratedPeer
protected int boundsOperation; protected int boundsOperation;
...@@ -128,9 +128,6 @@ public class XComponentPeer extends XWindow implements ComponentPeer, DropTarget ...@@ -128,9 +128,6 @@ public class XComponentPeer extends XWindow implements ComponentPeer, DropTarget
} }
void postInit(XCreateWindowParams params) { void postInit(XCreateWindowParams params) {
super.postInit(params); super.postInit(params);
Color c;
Font f;
Cursor cursor;
pSetCursor(target.getCursor()); pSetCursor(target.getCursor());
...@@ -143,19 +140,7 @@ public class XComponentPeer extends XWindow implements ComponentPeer, DropTarget ...@@ -143,19 +140,7 @@ public class XComponentPeer extends XWindow implements ComponentPeer, DropTarget
reshape(r.x, r.y, r.width, r.height); reshape(r.x, r.y, r.width, r.height);
} }
enabled = target.isEnabled(); setEnabled(target.isEnabled());
// If any of our heavyweight ancestors are disable, we should be too
// See 6176875 for more information
Component comp = target;
while( !(comp == null || comp instanceof Window) ) {
comp = comp.getParent();
if( comp != null && !comp.isEnabled() && !comp.isLightweight() ){
setEnabled(false);
break;
}
}
enableLog.fine("Initial enable state: {0}", Boolean.valueOf(enabled));
if (target.isVisible()) { if (target.isVisible()) {
setVisible(true); setVisible(true);
...@@ -384,45 +369,48 @@ public class XComponentPeer extends XWindow implements ComponentPeer, DropTarget ...@@ -384,45 +369,48 @@ public class XComponentPeer extends XWindow implements ComponentPeer, DropTarget
setVisible(false); setVisible(false);
} }
/** /**
* @see java.awt.peer.ComponentPeer * @see java.awt.peer.ComponentPeer
*/ */
public void setEnabled(boolean value) { public void setEnabled(final boolean value) {
enableLog.fine("{0}ing {1}", (value?"Enabl":"Disabl"), this); if (enableLog.isLoggable(PlatformLogger.FINE)) {
boolean repaintNeeded = (enabled != value); enableLog.fine("{0}ing {1}", (value ? "Enabl" : "Disabl"), this);
enabled = value; }
boolean status = value;
// If any of our heavyweight ancestors are disable, we should be too
// See 6176875 for more information
final Container cp = SunToolkit.getNativeContainer(target);
if (cp != null) {
status &= ((XComponentPeer) cp.getPeer()).isEnabled();
}
synchronized (getStateLock()) {
if (enabled == status) {
return;
}
enabled = status;
}
if (target instanceof Container) { if (target instanceof Container) {
Component list[] = ((Container)target).getComponents(); final Component[] list = ((Container) target).getComponents();
for (int i = 0; i < list.length; ++i) { for (final Component child : list) {
boolean childEnabled = list[i].isEnabled(); final ComponentPeer p = child.getPeer();
ComponentPeer p = list[i].getPeer(); if (p != null) {
if ( p != null ) { p.setEnabled(status && child.isEnabled());
p.setEnabled(value && childEnabled);
} }
} }
} }
if (repaintNeeded) {
repaint(); repaint();
} }
}
// //
// public so aw/Window can call it // public so aw/Window can call it
// //
public boolean isEnabled() { public final boolean isEnabled() {
synchronized (getStateLock()) {
return enabled; return enabled;
} }
public void enable() {
setEnabled(true);
} }
public void disable() {
setEnabled(false);
}
@Override @Override
public void paint(final Graphics g) { public void paint(final Graphics g) {
super.paint(g); super.paint(g);
......
/*
* Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
import sun.awt.SunToolkit;
import test.java.awt.regtesthelpers.Util;
import java.awt.AWTException;
import java.awt.Button;
import java.awt.Frame;
import java.awt.Robot;
import java.awt.Toolkit;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
/*
@test
@bug 7097771
@summary setEnabled does not work for components in disabled containers.
@author sergey.bylokhov@oracle.com: area=awt.component
@library ../../regtesthelpers
@build Util
@run main bug7097771
*/
public final class bug7097771 extends Frame implements ActionListener {
private static volatile boolean action;
public static void main(final String[] args) throws AWTException {
final bug7097771 frame = new bug7097771();
frame.setSize(300, 300);
frame.setLocationRelativeTo(null);
final Button button = new Button();
button.addActionListener(frame);
frame.add(button);
frame.setVisible(true);
sleep();
frame.setEnabled(false);
button.setEnabled(false);
button.setEnabled(true);
sleep();
Util.clickOnComp(button, new Robot());
sleep();
frame.dispose();
if (action) {
throw new RuntimeException("Button is not disabled.");
}
}
@Override
public void actionPerformed(final ActionEvent e) {
action = true;
}
private static void sleep() {
((SunToolkit) Toolkit.getDefaultToolkit()).realSync();
try {
Thread.sleep(1000);
} catch (InterruptedException ignored) {
}
}
}
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册