6690036: some code cleanup for insets-related code

All insets-related code from XWindowPeer, XFramePeer, and XDialogPeer has been moved to XDecoratedPeer.

Reviewed-by: anthony
This commit is contained in:
Oleg Sukhodolsky 2008-04-18 11:38:32 +04:00
parent 4b0c5dc3df
commit 0d2e60cbc6
4 changed files with 71 additions and 101 deletions

View File

@ -40,9 +40,7 @@ abstract class XDecoratedPeer extends XWindowPeer {
private static final Logger log = Logger.getLogger("sun.awt.X11.XDecoratedPeer");
private static final Logger insLog = Logger.getLogger("sun.awt.X11.insets.XDecoratedPeer");
private static final Logger focusLog = Logger.getLogger("sun.awt.X11.focus.XDecoratedPeer");
private final static Logger iconLog = Logger.getLogger("sun.awt.X11.icon.XDecoratedPeer");
private static XAtom resize_request = new XAtom("_SUN_AWT_RESIZE_REQUEST", false);
private static final Logger iconLog = Logger.getLogger("sun.awt.X11.icon.XDecoratedPeer");
// Set to true when we get the first ConfigureNotify after being
// reparented - indicates that WM has adopted the top-level.
@ -73,14 +71,11 @@ abstract class XDecoratedPeer extends XWindowPeer {
void preInit(XCreateWindowParams params) {
super.preInit(params);
if (!resize_request.isInterned()) {
resize_request.intern(false);
}
winAttr.initialFocus = true;
currentInsets = new Insets(0,0,0,0); // replacemenet for wdata->top, left, bottom, right
currentInsets = new Insets(0,0,0,0);
applyGuessedInsets();
Rectangle bounds = (Rectangle)params.get(BOUNDS);
dimensions = new WindowDimensions(bounds, getRealInsets(), false);
params.put(BOUNDS, dimensions.getClientRect());
@ -98,7 +93,10 @@ abstract class XDecoratedPeer extends XWindowPeer {
// happen after the X window is created.
initResizability();
updateSizeHints(dimensions);
XWM.requestWMExtents(getWindow());
content = XContentWindow.createContent(this);
if (warningWindow != null) {
warningWindow.toFront();
}
@ -121,7 +119,6 @@ abstract class XDecoratedPeer extends XWindowPeer {
updateMinSizeHints();
}
private void updateMinSizeHints() {
if (isResizable()) {
Dimension minimumSize = getTargetMinimumSize();
@ -238,23 +235,59 @@ abstract class XDecoratedPeer extends XWindowPeer {
return false;
}
Insets difference(Insets i1, Insets i2) {
private static Insets difference(Insets i1, Insets i2) {
return new Insets(i1.top-i2.top, i1.left - i2.left, i1.bottom-i2.bottom, i1.right-i2.right);
}
void add(Insets i1, Insets i2) {
i1.left += i2.left;
i1.top += i2.top;
i1.right += i2.right;
i1.bottom += i2.bottom;
}
boolean isNull(Insets i) {
private static boolean isNull(Insets i) {
return (i == null) || ((i.left | i.top | i.right | i.bottom) == 0);
}
Insets copy(Insets i) {
private static Insets copy(Insets i) {
return new Insets(i.top, i.left, i.bottom, i.right);
}
// insets which we get from WM (e.g from _NET_FRAME_EXTENTS)
private Insets wm_set_insets;
private Insets getWMSetInsets(XAtom changedAtom) {
if (isEmbedded()) {
return null;
}
if (wm_set_insets != null) {
return wm_set_insets;
}
if (changedAtom == null) {
wm_set_insets = XWM.getInsetsFromExtents(getWindow());
} else {
wm_set_insets = XWM.getInsetsFromProp(getWindow(), changedAtom);
}
insLog.log(Level.FINER, "FRAME_EXTENTS: {0}", new Object[]{wm_set_insets});
if (wm_set_insets != null) {
wm_set_insets = copy(wm_set_insets);
}
return wm_set_insets;
}
private void resetWMSetInsets() {
wm_set_insets = null;
}
public void handlePropertyNotify(XEvent xev) {
super.handlePropertyNotify(xev);
XPropertyEvent ev = xev.get_xproperty();
if (ev.get_atom() == XWM.XA_KDE_NET_WM_FRAME_STRUT.getAtom()
|| ev.get_atom() == XWM.XA_NET_FRAME_EXTENTS.getAtom())
{
getWMSetInsets(XAtom.get(ev.get_atom()));
}
}
long reparent_serial = 0;
public void handleReparentNotifyEvent(XEvent xev) {
@ -337,34 +370,29 @@ abstract class XDecoratedPeer extends XWindowPeer {
Insets correction = difference(correctWM, currentInsets);
insLog.log(Level.FINEST, "Corrention {0}", new Object[] {correction});
if (!isNull(correction)) {
/*
* Actual insets account for menubar/warning label,
* so we can't assign directly but must adjust them.
*/
add(currentInsets, correction);
currentInsets = copy(correctWM);
applyGuessedInsets();
//Fix for 6318109: PIT: Min Size is not honored properly when a
//smaller size is specified in setSize(), XToolkit
//update minimum size hints
updateMinSizeHints();
/*
* If this window has been sized by a pack() we need
* to keep the interior geometry intact. Since pack()
* computed width and height with wrong insets, we
* must adjust the target dimensions appropriately.
*/
}
if (insLog.isLoggable(Level.FINER)) insLog.finer("Dimensions before reparent: " + dimensions);
dimensions.setInsets(getRealInsets());
insets_corrected = true;
if (isMaximized()) {
if (isMaximized() || isNull(correction)) {
return;
}
/*
* If this window has been sized by a pack() we need
* to keep the interior geometry intact. Since pack()
* computed width and height with wrong insets, we
* must adjust the target dimensions appropriately.
*/
if ((getHints().get_flags() & (XUtilConstants.USPosition | XUtilConstants.PPosition)) != 0) {
reshape(dimensions, SET_BOUNDS, false);
} else {
@ -384,10 +412,10 @@ abstract class XDecoratedPeer extends XWindowPeer {
protected Insets guessInsets() {
if (isEmbedded()) {
if (isEmbedded() || isTargetUndecorated()) {
return new Insets(0, 0, 0, 0);
} else {
if (currentInsets.top > 0) {
if (!isNull(currentInsets)) {
/* insets were set on wdata by System Properties */
return copy(currentInsets);
} else {
@ -403,7 +431,6 @@ abstract class XDecoratedPeer extends XWindowPeer {
private void applyGuessedInsets() {
Insets guessed = guessInsets();
currentInsets = copy(guessed);
insets = copy(currentInsets);
}
public void revalidate() {
@ -416,16 +443,18 @@ abstract class XDecoratedPeer extends XWindowPeer {
}
Insets getRealInsets() {
if (isNull(insets)) {
if (isNull(currentInsets)) {
applyGuessedInsets();
}
return insets;
return currentInsets;
}
public Insets getInsets() {
Insets in = copy(getRealInsets());
in.top += getMenuBarHeight() + getWarningWindowHeight();
if (insLog.isLoggable(Level.FINEST)) insLog.log(Level.FINEST, "Get insets returns {0}", new Object[] {in});
if (insLog.isLoggable(Level.FINEST)) {
insLog.log(Level.FINEST, "Get insets returns {0}", new Object[] {in});
}
return in;
}
@ -835,7 +864,7 @@ abstract class XDecoratedPeer extends XWindowPeer {
public void setResizable(boolean resizable) {
int fs = winAttr.functions;
if (!isResizable() && resizable) {
insets = currentInsets = new Insets(0, 0, 0, 0);
currentInsets = new Insets(0, 0, 0, 0);
resetWMSetInsets();
if (!isEmbedded()) {
setReparented(false);
@ -849,7 +878,7 @@ abstract class XDecoratedPeer extends XWindowPeer {
winAttr.functions = fs;
XWM.setShellResizable(this);
} else if (isResizable() && !resizable) {
insets = currentInsets = new Insets(0, 0, 0, 0);
currentInsets = new Insets(0, 0, 0, 0);
resetWMSetInsets();
if (!isEmbedded()) {
setReparented(false);
@ -1004,10 +1033,6 @@ abstract class XDecoratedPeer extends XWindowPeer {
} else if (cl.get_data(0) == wm_take_focus.getAtom()) {
handleWmTakeFocus(cl);
}
} else if (cl.get_message_type() == resize_request.getAtom()) {
reshape((int)cl.get_data(0), (int)cl.get_data(1),
(int)cl.get_data(2), (int)cl.get_data(3),
(int)cl.get_data(4), true);
}
}

View File

@ -80,14 +80,6 @@ class XDialogPeer extends XDecoratedPeer implements DialogPeer {
super.setVisible(vis);
}
protected Insets guessInsets() {
if (isTargetUndecorated()) {
return new Insets(0, 0, 0, 0);
} else {
return super.guessInsets();
}
}
@Override
boolean isTargetUndecorated() {
if (undecorated != null) {

View File

@ -87,14 +87,6 @@ class XFramePeer extends XDecoratedPeer implements FramePeer {
setupState(true);
}
protected Insets guessInsets() {
if (isTargetUndecorated()) {
return new Insets(0, 0, 0, 0);
} else {
return super.guessInsets();
}
}
@Override
boolean isTargetUndecorated() {
if (undecorated != null) {

View File

@ -65,7 +65,6 @@ class XWindowPeer extends XPanelPeer implements WindowPeer,
static XAtom wm_delete_window;
static XAtom wm_take_focus;
Insets insets = new Insets( 0, 0, 0, 0 );
XWindowAttributesData winAttr;
private boolean cachedFocusableWindow;
XWarningWindow warningWindow;
@ -139,7 +138,6 @@ class XWindowPeer extends XPanelPeer implements WindowPeer,
XA_NET_WM_STATE = XAtom.get("_NET_WM_STATE");
winAttr = new XWindowAttributesData();
insets = new Insets(0,0,0,0);
params.put(OVERRIDE_REDIRECT, Boolean.valueOf(isOverrideRedirect()));
@ -260,7 +258,6 @@ class XWindowPeer extends XPanelPeer implements WindowPeer,
setSaveUnder(true);
XWM.requestWMExtents(getWindow());
updateIconImages();
}
@ -541,9 +538,7 @@ class XWindowPeer extends XPanelPeer implements WindowPeer,
}
public Insets getInsets() {
Insets in = (Insets)(insets.clone());
in.top += getWarningWindowHeight();
return in;
return new Insets(getWarningWindowHeight(), 0, 0, 0);
}
// NOTE: This method may be called by privileged threads.
@ -1002,7 +997,8 @@ class XWindowPeer extends XPanelPeer implements WindowPeer,
return ret;
}
private boolean isDesktopWindow( long wi ) {
private static boolean isDesktopWindow( long wi ) {
return XWM.getWM().isDesktopWindow( wi );
}
@ -1176,10 +1172,6 @@ class XWindowPeer extends XPanelPeer implements WindowPeer,
// State has changed, invalidate saved value
stateChanged = true;
stateChanged(ev.get_time(), savedState, getWMState());
} else if (ev.get_atom() == XWM.XA_KDE_NET_WM_FRAME_STRUT.getAtom()
|| ev.get_atom() == XWM.XA_NET_FRAME_EXTENTS.getAtom())
{
getWMSetInsets(XAtom.get(ev.get_atom()));
}
}
@ -1887,37 +1879,6 @@ class XWindowPeer extends XPanelPeer implements WindowPeer,
}
}
private Insets wm_set_insets;
public Insets getWMSetInsets(XAtom changedAtom) {
if (isEmbedded()) {
return null;
}
if (wm_set_insets != null) {
return wm_set_insets;
}
if (changedAtom == null) {
wm_set_insets = XWM.getInsetsFromExtents(getWindow());
} else {
wm_set_insets = XWM.getInsetsFromProp(getWindow(), changedAtom);
}
insLog.log(Level.FINER, "FRAME_EXTENTS: {0}", new Object[]{wm_set_insets});
if (wm_set_insets != null) {
handleWMSetInsets(wm_set_insets);
}
return wm_set_insets;
}
protected void handleWMSetInsets(Insets newInsets) {
wm_set_insets = (Insets)newInsets.clone();
}
public void resetWMSetInsets() {
wm_set_insets = null;
}
protected synchronized void updateDropTarget() {
if (dropTargetCount > 0) {
long window = getWindow();