Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
e3f4887c
D
dragonwell8_jdk
项目概览
openanolis
/
dragonwell8_jdk
通知
4
Star
2
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
dragonwell8_jdk
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
e3f4887c
编写于
8月 28, 2012
作者:
L
lana
浏览文件
操作
浏览文件
下载
差异文件
Merge
上级
fba2d1c2
ebd5d929
变更
32
显示空白变更内容
内联
并排
Showing
32 changed file
with
708 addition
and
120 deletion
+708
-120
make/common/Program.gmk
make/common/Program.gmk
+20
-0
make/sun/jawt/Makefile
make/sun/jawt/Makefile
+7
-0
src/macosx/classes/com/apple/laf/ScreenMenuItem.java
src/macosx/classes/com/apple/laf/ScreenMenuItem.java
+20
-10
src/macosx/classes/com/apple/laf/ScreenMenuItemCheckbox.java
src/macosx/classes/com/apple/laf/ScreenMenuItemCheckbox.java
+8
-13
src/macosx/classes/sun/java2d/opengl/CGLGraphicsConfig.java
src/macosx/classes/sun/java2d/opengl/CGLGraphicsConfig.java
+54
-1
src/macosx/classes/sun/lwawt/LWComponentPeer.java
src/macosx/classes/sun/lwawt/LWComponentPeer.java
+1
-1
src/macosx/classes/sun/lwawt/LWWindowPeer.java
src/macosx/classes/sun/lwawt/LWWindowPeer.java
+36
-5
src/macosx/classes/sun/lwawt/PlatformComponent.java
src/macosx/classes/sun/lwawt/PlatformComponent.java
+28
-5
src/macosx/classes/sun/lwawt/PlatformWindow.java
src/macosx/classes/sun/lwawt/PlatformWindow.java
+4
-1
src/macosx/classes/sun/lwawt/macosx/CFRetainedResource.java
src/macosx/classes/sun/lwawt/macosx/CFRetainedResource.java
+2
-2
src/macosx/classes/sun/lwawt/macosx/CFileDialog.java
src/macosx/classes/sun/lwawt/macosx/CFileDialog.java
+7
-1
src/macosx/classes/sun/lwawt/macosx/CPlatformComponent.java
src/macosx/classes/sun/lwawt/macosx/CPlatformComponent.java
+19
-21
src/macosx/classes/sun/lwawt/macosx/CPlatformEmbeddedFrame.java
...cosx/classes/sun/lwawt/macosx/CPlatformEmbeddedFrame.java
+1
-1
src/macosx/classes/sun/lwawt/macosx/CPlatformWindow.java
src/macosx/classes/sun/lwawt/macosx/CPlatformWindow.java
+3
-8
src/macosx/native/sun/awt/AWTSurfaceLayers.m
src/macosx/native/sun/awt/AWTSurfaceLayers.m
+2
-3
src/macosx/native/sun/awt/CFileDialog.h
src/macosx/native/sun/awt/CFileDialog.h
+4
-0
src/macosx/native/sun/awt/CFileDialog.m
src/macosx/native/sun/awt/CFileDialog.m
+6
-2
src/macosx/native/sun/java2d/opengl/CGLGraphicsConfig.m
src/macosx/native/sun/java2d/opengl/CGLGraphicsConfig.m
+17
-0
src/macosx/native/sun/osxapp/NSApplicationAWT.h
src/macosx/native/sun/osxapp/NSApplicationAWT.h
+0
-1
src/macosx/native/sun/osxapp/NSApplicationAWT.m
src/macosx/native/sun/osxapp/NSApplicationAWT.m
+5
-10
src/share/classes/java/awt/Component.java
src/share/classes/java/awt/Component.java
+1
-1
src/share/classes/java/awt/EventQueue.java
src/share/classes/java/awt/EventQueue.java
+5
-1
src/share/classes/java/beans/PropertyDescriptor.java
src/share/classes/java/beans/PropertyDescriptor.java
+1
-1
src/share/classes/javax/swing/JTable.java
src/share/classes/javax/swing/JTable.java
+2
-2
src/share/classes/sun/awt/TextureSizeConstraining.java
src/share/classes/sun/awt/TextureSizeConstraining.java
+45
-0
test/java/awt/Frame/HugeFrame/HugeFrame.java
test/java/awt/Frame/HugeFrame/HugeFrame.java
+22
-13
test/java/beans/Introspector/Test7189112.java
test/java/beans/Introspector/Test7189112.java
+64
-0
test/javax/swing/JColorChooser/Test4380468.html
test/javax/swing/JColorChooser/Test4380468.html
+0
-17
test/javax/swing/JSplitPane/4201995/bug4201995.java
test/javax/swing/JSplitPane/4201995/bug4201995.java
+47
-0
test/javax/swing/JTable/4235420/bug4235420.java
test/javax/swing/JTable/4235420/bug4235420.java
+87
-0
test/javax/swing/JTable/7188612/JTableAccessibleGetLocationOnScreen.java
...g/JTable/7188612/JTableAccessibleGetLocationOnScreen.java
+106
-0
test/tools/launcher/RunpathTest.java
test/tools/launcher/RunpathTest.java
+84
-0
未找到文件。
make/common/Program.gmk
浏览文件 @
e3f4887c
...
@@ -125,6 +125,26 @@ ifeq ($(PLATFORM), windows)
...
@@ -125,6 +125,26 @@ ifeq ($(PLATFORM), windows)
OTHER_LDLIBS += jli.lib
OTHER_LDLIBS += jli.lib
endif
endif
#
# Applications expect to be able to link against libjawt without invoking
# System.loadLibrary("jawt") first. This was the behaviour described in the
# devloper documentation of JAWT and what worked with OpenJDK6.
#
ifeq ($(PLATFORM), solaris)
ifeq ($(ARCH_DATA_MODEL), 32)
LDFLAGS += -R \$$ORIGIN/../lib/$(LIBARCH)
LDFLAGS += -R \$$ORIGIN/../jre/lib/$(LIBARCH)
else # ! ARCH_DATA_MODEL 64-bit
LDFLAGS += -R \$$ORIGIN/../../lib/$(LIBARCH)
LDFLAGS += -R \$$ORIGIN/../../jre/lib/$(LIBARCH)
endif # ARCH_DATA_MODEL
endif # PLATFORM SOLARIS
ifeq ($(PLATFORM), linux)
LDFLAGS += -Wl,-rpath -Wl,\$$ORIGIN/../lib/$(LIBARCH)
LDFLAGS += -Wl,-rpath -Wl,\$$ORIGIN/../jre/lib/$(LIBARCH)
endif # PLATFORM LINUX
#
#
# Launcher specific files.
# Launcher specific files.
#
#
...
...
make/sun/jawt/Makefile
浏览文件 @
e3f4887c
...
@@ -30,6 +30,13 @@ PRODUCT = sun
...
@@ -30,6 +30,13 @@ PRODUCT = sun
include
$(BUILDDIR)/common/Defs.gmk
include
$(BUILDDIR)/common/Defs.gmk
#
# libjawt links to other programs, but nothing links to it directly. An RPATH
# entry has been added to the launcher so third-party programs linked against
# it will be able to find it no matter where the JDK or the third-party program
# is located.
#
#
#
# Files
# Files
#
#
...
...
src/macosx/classes/com/apple/laf/ScreenMenuItem.java
浏览文件 @
e3f4887c
...
@@ -34,7 +34,7 @@ import javax.swing.plaf.ComponentUI;
...
@@ -34,7 +34,7 @@ import javax.swing.plaf.ComponentUI;
import
sun.lwawt.macosx.CMenuItem
;
import
sun.lwawt.macosx.CMenuItem
;
class
ScreenMenuItem
extends
MenuItem
implements
ActionListener
,
ComponentListener
,
ScreenMenuPropertyHandler
{
final
class
ScreenMenuItem
extends
MenuItem
implements
ActionListener
,
ComponentListener
,
ScreenMenuPropertyHandler
{
ScreenMenuPropertyListener
fListener
;
ScreenMenuPropertyListener
fListener
;
JMenuItem
fMenuItem
;
JMenuItem
fMenuItem
;
...
@@ -96,21 +96,31 @@ class ScreenMenuItem extends MenuItem implements ActionListener, ComponentListen
...
@@ -96,21 +96,31 @@ class ScreenMenuItem extends MenuItem implements ActionListener, ComponentListen
fMenuItem
.
removeComponentListener
(
this
);
fMenuItem
.
removeComponentListener
(
this
);
}
}
public
void
setAccelerator
(
final
KeyStroke
ks
)
{
static
void
syncLabelAndKS
(
MenuItem
menuItem
,
String
label
,
KeyStroke
ks
)
{
if
(
ks
==
null
)
{
final
MenuComponentPeer
peer
=
menuItem
.
getPeer
();
setShortcut
(
null
);
if
(!(
peer
instanceof
CMenuItem
))
{
//Is it possible?
return
;
return
;
}
}
final
CMenuItem
cmi
=
(
CMenuItem
)
peer
;
final
MenuComponentPeer
peer
=
getPeer
();
if
(
ks
==
null
)
{
if
(
peer
instanceof
CMenuItem
)
{
cmi
.
setLabel
(
label
);
final
CMenuItem
ourPeer
=
(
CMenuItem
)
peer
;
ourPeer
.
setLabel
(
fMenuItem
.
getText
(),
ks
.
getKeyChar
(),
ks
.
getKeyCode
(),
ks
.
getModifiers
());
}
else
{
}
else
{
setShortcut
(
new
MenuShortcut
(
ks
.
getKeyCode
(),
(
ks
.
getModifiers
()
&
InputEvent
.
SHIFT_MASK
)
!=
0
));
cmi
.
setLabel
(
label
,
ks
.
getKeyChar
(),
ks
.
getKeyCode
(),
ks
.
getModifiers
());
}
}
}
}
@Override
public
synchronized
void
setLabel
(
final
String
label
)
{
syncLabelAndKS
(
this
,
label
,
fMenuItem
.
getAccelerator
());
}
@Override
public
void
setAccelerator
(
final
KeyStroke
ks
)
{
syncLabelAndKS
(
this
,
fMenuItem
.
getText
(),
ks
);
}
public
void
actionPerformed
(
final
ActionEvent
e
)
{
public
void
actionPerformed
(
final
ActionEvent
e
)
{
fMenuItem
.
doClick
(
0
);
// This takes care of all the different events
fMenuItem
.
doClick
(
0
);
// This takes care of all the different events
}
}
...
...
src/macosx/classes/com/apple/laf/ScreenMenuItemCheckbox.java
浏览文件 @
e3f4887c
...
@@ -36,7 +36,7 @@ import com.apple.laf.AquaMenuItemUI.IndeterminateListener;
...
@@ -36,7 +36,7 @@ import com.apple.laf.AquaMenuItemUI.IndeterminateListener;
import
sun.lwawt.macosx.*
;
import
sun.lwawt.macosx.*
;
class
ScreenMenuItemCheckbox
extends
CheckboxMenuItem
implements
ActionListener
,
ComponentListener
,
ScreenMenuPropertyHandler
,
ItemListener
{
final
class
ScreenMenuItemCheckbox
extends
CheckboxMenuItem
implements
ActionListener
,
ComponentListener
,
ScreenMenuPropertyHandler
,
ItemListener
{
JMenuItem
fMenuItem
;
JMenuItem
fMenuItem
;
MenuContainer
fParent
;
MenuContainer
fParent
;
...
@@ -110,19 +110,14 @@ class ScreenMenuItemCheckbox extends CheckboxMenuItem implements ActionListener,
...
@@ -110,19 +110,14 @@ class ScreenMenuItemCheckbox extends CheckboxMenuItem implements ActionListener,
super
.
removeNotify
();
super
.
removeNotify
();
}
}
public
void
setAccelerator
(
final
KeyStroke
ks
)
{
@Override
if
(
ks
==
null
)
{
public
synchronized
void
setLabel
(
final
String
label
)
{
setShortcut
(
null
);
ScreenMenuItem
.
syncLabelAndKS
(
this
,
label
,
fMenuItem
.
getAccelerator
());
return
;
}
}
final
MenuComponentPeer
peer
=
getPeer
();
@Override
if
(
peer
instanceof
CMenuItem
)
{
public
void
setAccelerator
(
final
KeyStroke
ks
)
{
final
CMenuItem
ourPeer
=
(
CMenuItem
)
peer
;
ScreenMenuItem
.
syncLabelAndKS
(
this
,
fMenuItem
.
getText
(),
ks
);
ourPeer
.
setLabel
(
fMenuItem
.
getText
(),
ks
.
getKeyChar
(),
ks
.
getKeyCode
(),
ks
.
getModifiers
());
}
else
{
setShortcut
(
new
MenuShortcut
(
ks
.
getKeyCode
(),
(
ks
.
getModifiers
()
&
InputEvent
.
SHIFT_MASK
)
!=
0
));
}
}
}
public
void
actionPerformed
(
final
ActionEvent
e
)
{
public
void
actionPerformed
(
final
ActionEvent
e
)
{
...
...
src/macosx/classes/sun/java2d/opengl/CGLGraphicsConfig.java
浏览文件 @
e3f4887c
...
@@ -31,8 +31,12 @@ import java.awt.Color;
...
@@ -31,8 +31,12 @@ import java.awt.Color;
import
java.awt.Component
;
import
java.awt.Component
;
import
java.awt.Graphics
;
import
java.awt.Graphics
;
import
java.awt.Graphics2D
;
import
java.awt.Graphics2D
;
import
java.awt.GraphicsConfiguration
;
import
java.awt.GraphicsDevice
;
import
java.awt.GraphicsEnvironment
;
import
java.awt.Image
;
import
java.awt.Image
;
import
java.awt.ImageCapabilities
;
import
java.awt.ImageCapabilities
;
import
java.awt.Rectangle
;
import
java.awt.Transparency
;
import
java.awt.Transparency
;
import
java.awt.color.ColorSpace
;
import
java.awt.color.ColorSpace
;
import
java.awt.image.BufferedImage
;
import
java.awt.image.BufferedImage
;
...
@@ -44,6 +48,7 @@ import java.awt.image.WritableRaster;
...
@@ -44,6 +48,7 @@ import java.awt.image.WritableRaster;
import
sun.awt.CGraphicsConfig
;
import
sun.awt.CGraphicsConfig
;
import
sun.awt.CGraphicsDevice
;
import
sun.awt.CGraphicsDevice
;
import
sun.awt.TextureSizeConstraining
;
import
sun.awt.image.OffScreenImage
;
import
sun.awt.image.OffScreenImage
;
import
sun.awt.image.SunVolatileImage
;
import
sun.awt.image.SunVolatileImage
;
import
sun.awt.image.SurfaceManager
;
import
sun.awt.image.SurfaceManager
;
...
@@ -65,7 +70,7 @@ import sun.java2d.pipe.hw.AccelDeviceEventNotifier;
...
@@ -65,7 +70,7 @@ import sun.java2d.pipe.hw.AccelDeviceEventNotifier;
import
sun.lwawt.macosx.CPlatformView
;
import
sun.lwawt.macosx.CPlatformView
;
public
class
CGLGraphicsConfig
extends
CGraphicsConfig
public
class
CGLGraphicsConfig
extends
CGraphicsConfig
implements
OGLGraphicsConfig
implements
OGLGraphicsConfig
,
TextureSizeConstraining
{
{
//private static final int kOpenGLSwapInterval = RuntimeOptions.getCurrentOptions().OpenGLSwapInterval;
//private static final int kOpenGLSwapInterval = RuntimeOptions.getCurrentOptions().OpenGLSwapInterval;
private
static
final
int
kOpenGLSwapInterval
=
0
;
// TODO
private
static
final
int
kOpenGLSwapInterval
=
0
;
// TODO
...
@@ -242,6 +247,8 @@ public class CGLGraphicsConfig extends CGraphicsConfig
...
@@ -242,6 +247,8 @@ public class CGLGraphicsConfig extends CGraphicsConfig
}
finally
{
}
finally
{
rq
.
unlock
();
rq
.
unlock
();
}
}
updateTotalDisplayBounds
();
}
}
@Override
@Override
...
@@ -478,4 +485,50 @@ public class CGLGraphicsConfig extends CGraphicsConfig
...
@@ -478,4 +485,50 @@ public class CGLGraphicsConfig extends CGraphicsConfig
public
void
removeDeviceEventListener
(
AccelDeviceEventListener
l
)
{
public
void
removeDeviceEventListener
(
AccelDeviceEventListener
l
)
{
AccelDeviceEventNotifier
.
removeListener
(
l
);
AccelDeviceEventNotifier
.
removeListener
(
l
);
}
}
private
static
final
Rectangle
totalDisplayBounds
=
new
Rectangle
();
private
static
void
updateTotalDisplayBounds
()
{
synchronized
(
totalDisplayBounds
)
{
Rectangle
virtualBounds
=
new
Rectangle
();
for
(
GraphicsDevice
gd
:
GraphicsEnvironment
.
getLocalGraphicsEnvironment
().
getScreenDevices
())
{
for
(
GraphicsConfiguration
gc
:
gd
.
getConfigurations
())
{
virtualBounds
=
virtualBounds
.
union
(
gc
.
getBounds
());
}
}
totalDisplayBounds
.
setBounds
(
virtualBounds
);
}
}
// 7160609: GL still fails to create a square texture of this size,
// so we use this value to cap the total display bounds.
native
private
static
int
getMaxTextureSize
();
@Override
public
int
getMaxTextureWidth
()
{
int
width
;
synchronized
(
totalDisplayBounds
)
{
if
(
totalDisplayBounds
.
width
==
0
)
{
updateTotalDisplayBounds
();
}
width
=
totalDisplayBounds
.
width
;
}
return
Math
.
min
(
width
,
getMaxTextureSize
());
}
@Override
public
int
getMaxTextureHeight
()
{
int
height
;
synchronized
(
totalDisplayBounds
)
{
if
(
totalDisplayBounds
.
height
==
0
)
{
updateTotalDisplayBounds
();
}
height
=
totalDisplayBounds
.
height
;
}
return
Math
.
min
(
height
,
getMaxTextureSize
());
}
}
}
src/macosx/classes/sun/lwawt/LWComponentPeer.java
浏览文件 @
e3f4887c
...
@@ -282,7 +282,7 @@ public abstract class LWComponentPeer<T extends Component, D extends JComponent>
...
@@ -282,7 +282,7 @@ public abstract class LWComponentPeer<T extends Component, D extends JComponent>
* Note that we call setVisible() at the end of initialization.
* Note that we call setVisible() at the end of initialization.
*/
*/
public
final
void
initialize
()
{
public
final
void
initialize
()
{
platformComponent
.
initialize
(
target
,
this
,
getPlatformWindow
());
platformComponent
.
initialize
(
getPlatformWindow
());
initializeImpl
();
initializeImpl
();
setVisible
(
target
.
isVisible
());
setVisible
(
target
.
isVisible
());
}
}
...
...
src/macosx/classes/sun/lwawt/LWWindowPeer.java
浏览文件 @
e3f4887c
...
@@ -338,6 +338,18 @@ public class LWWindowPeer
...
@@ -338,6 +338,18 @@ public class LWWindowPeer
h
=
MINIMUM_HEIGHT
;
h
=
MINIMUM_HEIGHT
;
}
}
if
(
graphicsConfig
instanceof
TextureSizeConstraining
)
{
final
int
maxW
=
((
TextureSizeConstraining
)
graphicsConfig
).
getMaxTextureWidth
();
final
int
maxH
=
((
TextureSizeConstraining
)
graphicsConfig
).
getMaxTextureHeight
();
if
(
w
>
maxW
)
{
w
=
maxW
;
}
if
(
h
>
maxH
)
{
h
=
maxH
;
}
}
// Don't post ComponentMoved/Resized and Paint events
// Don't post ComponentMoved/Resized and Paint events
// until we've got a notification from the delegate
// until we've got a notification from the delegate
setBounds
(
x
,
y
,
w
,
h
,
op
,
false
,
false
);
setBounds
(
x
,
y
,
w
,
h
,
op
,
false
,
false
);
...
@@ -405,14 +417,33 @@ public class LWWindowPeer
...
@@ -405,14 +417,33 @@ public class LWWindowPeer
@Override
@Override
public
void
updateMinimumSize
()
{
public
void
updateMinimumSize
()
{
Dimension
d
=
null
;
final
Dimension
min
;
if
(
getTarget
().
isMinimumSizeSet
())
{
if
(
getTarget
().
isMinimumSizeSet
())
{
d
=
getTarget
().
getMinimumSize
();
min
=
getTarget
().
getMinimumSize
();
min
.
width
=
Math
.
max
(
min
.
width
,
MINIMUM_WIDTH
);
min
.
height
=
Math
.
max
(
min
.
height
,
MINIMUM_HEIGHT
);
}
else
{
min
=
new
Dimension
(
MINIMUM_WIDTH
,
MINIMUM_HEIGHT
);
}
}
if
(
d
==
null
)
{
d
=
new
Dimension
(
MINIMUM_WIDTH
,
MINIMUM_HEIGHT
);
final
int
maxW
,
maxH
;
if
(
graphicsConfig
instanceof
TextureSizeConstraining
)
{
maxW
=
((
TextureSizeConstraining
)
graphicsConfig
).
getMaxTextureWidth
();
maxH
=
((
TextureSizeConstraining
)
graphicsConfig
).
getMaxTextureHeight
();
}
else
{
maxW
=
maxH
=
Integer
.
MAX_VALUE
;
}
final
Dimension
max
;
if
(
getTarget
().
isMaximumSizeSet
())
{
max
=
getTarget
().
getMaximumSize
();
max
.
width
=
Math
.
min
(
max
.
width
,
maxW
);
max
.
height
=
Math
.
min
(
max
.
height
,
maxH
);
}
else
{
max
=
new
Dimension
(
maxW
,
maxH
);
}
}
platformWindow
.
setMinimumSize
(
d
.
width
,
d
.
height
);
platformWindow
.
setSizeConstraints
(
min
.
width
,
min
.
height
,
max
.
width
,
max
.
height
);
}
}
@Override
@Override
...
...
src/macosx/classes/sun/lwawt/PlatformComponent.java
浏览文件 @
e3f4887c
...
@@ -23,15 +23,38 @@
...
@@ -23,15 +23,38 @@
* questions.
* questions.
*/
*/
package
sun.lwawt
;
import
java.awt.Componen
t
;
package
sun.lwaw
t
;
/**
* Can be used to store information about native resource related to the
* lightweight component.
*/
public
interface
PlatformComponent
{
public
interface
PlatformComponent
{
public
void
initialize
(
Component
target
,
LWComponentPeer
peer
,
PlatformWindow
platformWindow
);
/**
* Initializes platform component.
*
* @param platformWindow already initialized {@code PlatformWindow}.
*/
void
initialize
(
PlatformWindow
platformWindow
);
public
void
setBounds
(
int
x
,
int
y
,
int
w
,
int
h
);
/**
* Moves and resizes this component. The new location of the top-left corner
* is specified by {@code x} and {@code y}, and the new size is specified by
* {@code w} and {@code h}. The location is specified relative to the {@code
* platformWindow}.
*
* @param x the X location of the component
* @param y the Y location of the component
* @param w the width of the component
* @param h the height of the component
*/
void
setBounds
(
int
x
,
int
y
,
int
w
,
int
h
);
public
void
dispose
();
/**
* Releases all of the native resources used by this {@code
* PlatformComponent}.
*/
void
dispose
();
}
}
src/macosx/classes/sun/lwawt/PlatformWindow.java
浏览文件 @
e3f4887c
...
@@ -131,7 +131,10 @@ public interface PlatformWindow {
...
@@ -131,7 +131,10 @@ public interface PlatformWindow {
public
void
setResizable
(
boolean
resizable
);
public
void
setResizable
(
boolean
resizable
);
public
void
setMinimumSize
(
int
width
,
int
height
);
/**
* Applies the minimum and maximum size to the platform window.
*/
public
void
setSizeConstraints
(
int
minW
,
int
minH
,
int
maxW
,
int
maxH
);
/**
/**
* Transforms the given Graphics object according to the native
* Transforms the given Graphics object according to the native
...
...
src/macosx/classes/sun/lwawt/macosx/CFRetainedResource.java
浏览文件 @
e3f4887c
...
@@ -33,8 +33,8 @@ package sun.lwawt.macosx;
...
@@ -33,8 +33,8 @@ package sun.lwawt.macosx;
public
class
CFRetainedResource
{
public
class
CFRetainedResource
{
private
static
native
void
nativeCFRelease
(
final
long
ptr
,
final
boolean
disposeOnAppKitThread
);
private
static
native
void
nativeCFRelease
(
final
long
ptr
,
final
boolean
disposeOnAppKitThread
);
final
boolean
disposeOnAppKitThread
;
private
final
boolean
disposeOnAppKitThread
;
protected
long
ptr
;
protected
volatile
long
ptr
;
/**
/**
* @param ptr CFRetained native object pointer
* @param ptr CFRetained native object pointer
...
...
src/macosx/classes/sun/lwawt/macosx/CFileDialog.java
浏览文件 @
e3f4887c
...
@@ -30,12 +30,14 @@ import java.awt.peer.*;
...
@@ -30,12 +30,14 @@ import java.awt.peer.*;
import
java.awt.BufferCapabilities.FlipContents
;
import
java.awt.BufferCapabilities.FlipContents
;
import
java.awt.event.*
;
import
java.awt.event.*
;
import
java.awt.image.*
;
import
java.awt.image.*
;
import
java.security.AccessController
;
import
java.util.List
;
import
java.util.List
;
import
java.io.*
;
import
java.io.*
;
import
sun.awt.CausedFocusEvent.Cause
;
import
sun.awt.CausedFocusEvent.Cause
;
import
sun.awt.AWTAccessor
;
import
sun.awt.AWTAccessor
;
import
sun.java2d.pipe.Region
;
import
sun.java2d.pipe.Region
;
import
sun.security.action.GetBooleanAction
;
class
CFileDialog
implements
FileDialogPeer
{
class
CFileDialog
implements
FileDialogPeer
{
...
@@ -53,11 +55,14 @@ class CFileDialog implements FileDialogPeer {
...
@@ -53,11 +55,14 @@ class CFileDialog implements FileDialogPeer {
if
(
title
==
null
)
{
if
(
title
==
null
)
{
title
=
" "
;
title
=
" "
;
}
}
Boolean
chooseDirectories
=
AccessController
.
doPrivileged
(
new
GetBooleanAction
(
"apple.awt.fileDialogForDirectories"
));
String
[]
userFileNames
=
nativeRunFileDialog
(
title
,
String
[]
userFileNames
=
nativeRunFileDialog
(
title
,
dialogMode
,
dialogMode
,
target
.
isMultipleMode
(),
target
.
isMultipleMode
(),
navigateApps
,
navigateApps
,
chooseDirectories
,
target
.
getFilenameFilter
()
!=
null
,
target
.
getFilenameFilter
()
!=
null
,
target
.
getDirectory
(),
target
.
getDirectory
(),
target
.
getFile
());
target
.
getFile
());
...
@@ -142,7 +147,8 @@ class CFileDialog implements FileDialogPeer {
...
@@ -142,7 +147,8 @@ class CFileDialog implements FileDialogPeer {
}
}
private
native
String
[]
nativeRunFileDialog
(
String
title
,
int
mode
,
private
native
String
[]
nativeRunFileDialog
(
String
title
,
int
mode
,
boolean
multipleMode
,
boolean
shouldNavigateApps
,
boolean
hasFilenameFilter
,
boolean
multipleMode
,
boolean
shouldNavigateApps
,
boolean
canChooseDirectories
,
boolean
hasFilenameFilter
,
String
directory
,
String
file
);
String
directory
,
String
file
);
@Override
@Override
...
...
src/macosx/classes/sun/lwawt/macosx/CPlatformComponent.java
浏览文件 @
e3f4887c
...
@@ -23,27 +23,24 @@
...
@@ -23,27 +23,24 @@
* questions.
* questions.
*/
*/
package
sun.lwawt.macosx
;
package
sun.lwawt.macosx
;
import
java.awt.Component
;
import
java.awt.Insets
;
import
java.awt.Insets
;
import
sun.lwawt.PlatformComponent
;
import
sun.lwawt.PlatformComponent
;
import
sun.lwawt.PlatformWindow
;
import
sun.lwawt.PlatformWindow
;
import
sun.lwawt.LWComponentPeer
;
import
sun.lwawt.macosx.CFRetainedResource
;
public
class
CPlatformComponent
extends
CFRetainedResource
implements
PlatformComponent
{
Component
target
;
/**
LWComponentPeer
peer
;
* On OSX {@code CPlatformComponent} stores pointer to the native CAlayer which
PlatformWindow
platformWindow
;
* can be used from JAWT.
*/
final
class
CPlatformComponent
extends
CFRetainedResource
implements
PlatformComponent
{
private
native
long
nativeCreateComponent
(
long
windowLayer
);
private
volatile
PlatformWindow
platformWindow
;
private
native
long
nativeSetBounds
(
long
ptr
,
int
x
,
int
y
,
int
width
,
int
height
);
public
CPlatformComponent
()
{
CPlatformComponent
()
{
super
(
0
,
true
);
super
(
0
,
true
);
}
}
...
@@ -51,27 +48,28 @@ public class CPlatformComponent extends CFRetainedResource implements PlatformCo
...
@@ -51,27 +48,28 @@ public class CPlatformComponent extends CFRetainedResource implements PlatformCo
return
ptr
;
return
ptr
;
}
}
public
void
initialize
(
Component
target
,
LWComponentPeer
peer
,
PlatformWindow
platformWindow
)
{
@Override
this
.
target
=
target
;
public
void
initialize
(
final
PlatformWindow
platformWindow
)
{
this
.
peer
=
peer
;
this
.
platformWindow
=
platformWindow
;
this
.
platformWindow
=
platformWindow
;
setPtr
(
nativeCreateComponent
(
platformWindow
.
getLayerPtr
()));
long
windowLayerPtr
=
platformWindow
.
getLayerPtr
();
setPtr
(
nativeCreateComponent
(
windowLayerPtr
));
}
}
// TODO: visibility, z-order
// TODO: visibility, z-order
@Override
@Override
public
void
setBounds
(
int
x
,
int
y
,
int
width
,
int
height
)
{
public
void
setBounds
(
final
int
x
,
final
int
y
,
final
int
w
,
final
int
h
)
{
// translates values from the coordinate system of the top-level window
// translates values from the coordinate system of the top-level window
// to the coordinate system of the content view
// to the coordinate system of the content view
Insets
insets
=
platformWindow
.
getPeer
().
getInsets
();
final
Insets
insets
=
platformWindow
.
getPeer
().
getInsets
();
nativeSetBounds
(
getPointer
(),
x
-
insets
.
left
,
y
-
insets
.
top
,
w
idth
,
height
);
nativeSetBounds
(
getPointer
(),
x
-
insets
.
left
,
y
-
insets
.
top
,
w
,
h
);
}
}
@Override
@Override
public
void
dispose
()
{
public
void
dispose
()
{
super
.
dispose
();
super
.
dispose
();
}
}
private
native
long
nativeCreateComponent
(
long
windowLayer
);
private
native
void
nativeSetBounds
(
long
ptr
,
int
x
,
int
y
,
int
w
,
int
h
);
}
}
src/macosx/classes/sun/lwawt/macosx/CPlatformEmbeddedFrame.java
浏览文件 @
e3f4887c
...
@@ -180,7 +180,7 @@ public class CPlatformEmbeddedFrame implements PlatformWindow {
...
@@ -180,7 +180,7 @@ public class CPlatformEmbeddedFrame implements PlatformWindow {
public
void
setResizable
(
boolean
resizable
)
{}
public
void
setResizable
(
boolean
resizable
)
{}
@Override
@Override
public
void
set
MinimumSize
(
int
width
,
int
height
)
{}
public
void
set
SizeConstraints
(
int
minW
,
int
minH
,
int
maxW
,
int
maxH
)
{}
@Override
@Override
public
Graphics
transformGraphics
(
Graphics
g
)
{
public
Graphics
transformGraphics
(
Graphics
g
)
{
...
...
src/macosx/classes/sun/lwawt/macosx/CPlatformWindow.java
浏览文件 @
e3f4887c
...
@@ -672,20 +672,15 @@ public class CPlatformWindow extends CFRetainedResource implements PlatformWindo
...
@@ -672,20 +672,15 @@ public class CPlatformWindow extends CFRetainedResource implements PlatformWindo
// Re-apply the size constraints and the size to ensure the space
// Re-apply the size constraints and the size to ensure the space
// occupied by the grow box is counted properly
// occupied by the grow box is counted properly
setMinimumSize
(
1
,
1
);
// the method ignores its arguments
peer
.
updateMinimumSize
();
Rectangle
bounds
=
peer
.
getBounds
();
Rectangle
bounds
=
peer
.
getBounds
();
setBounds
(
bounds
.
x
,
bounds
.
y
,
bounds
.
width
,
bounds
.
height
);
setBounds
(
bounds
.
x
,
bounds
.
y
,
bounds
.
width
,
bounds
.
height
);
}
}
@Override
@Override
public
void
setMinimumSize
(
int
width
,
int
height
)
{
public
void
setSizeConstraints
(
int
minW
,
int
minH
,
int
maxW
,
int
maxH
)
{
//TODO width, height should be used
nativeSetNSWindowMinMax
(
getNSWindowPtr
(),
minW
,
minH
,
maxW
,
maxH
);
//NOTE: setResizable() calls setMinimumSize(1,1) relaying on the logic below
final
long
nsWindowPtr
=
getNSWindowPtr
();
final
Dimension
min
=
target
.
getMinimumSize
();
final
Dimension
max
=
target
.
getMaximumSize
();
nativeSetNSWindowMinMax
(
nsWindowPtr
,
min
.
getWidth
(),
min
.
getHeight
(),
max
.
getWidth
(),
max
.
getHeight
());
}
}
@Override
@Override
...
...
src/macosx/native/sun/awt/AWTSurfaceLayers.m
浏览文件 @
e3f4887c
...
@@ -78,11 +78,10 @@
...
@@ -78,11 +78,10 @@
// translates values to the coordinate system of the "root" layer
// translates values to the coordinate system of the "root" layer
CGFloat
newY
=
windowLayer
.
bounds
.
size
.
height
-
rect
.
origin
.
y
-
rect
.
size
.
height
;
CGFloat
newY
=
windowLayer
.
bounds
.
size
.
height
-
rect
.
origin
.
y
-
rect
.
size
.
height
;
CGRect
newRect
=
CGRectMake
(
rect
.
origin
.
x
,
newY
,
rect
.
size
.
width
,
rect
.
size
.
height
);
// REMIND: why do we need to inverse position?
layer
.
frame
=
newRect
;
CGRect
newRect
=
CGRectMake
(
-
rect
.
origin
.
x
,
-
newY
,
rect
.
size
.
width
,
rect
.
size
.
height
);
layer
.
bounds
=
newRect
;
[
AWTSurfaceLayers
repaintLayersRecursively
:
layer
];
[
AWTSurfaceLayers
repaintLayersRecursively
:
layer
];
}
}
...
...
src/macosx/native/sun/awt/CFileDialog.h
浏览文件 @
e3f4887c
...
@@ -52,6 +52,9 @@
...
@@ -52,6 +52,9 @@
// Should we navigate into apps?
// Should we navigate into apps?
BOOL
fNavigateApps
;
BOOL
fNavigateApps
;
// Can the dialog choose directories ?
BOOL
fChooseDirectories
;
// Contains the absolute paths of the selected files as URLs
// Contains the absolute paths of the selected files as URLs
NSArray
*
fURLs
;
NSArray
*
fURLs
;
}
}
...
@@ -65,6 +68,7 @@
...
@@ -65,6 +68,7 @@
mode
:(
jint
)
inMode
mode
:(
jint
)
inMode
multipleMode
:(
BOOL
)
inMultipleMode
multipleMode
:(
BOOL
)
inMultipleMode
shouldNavigate
:(
BOOL
)
inNavigateApps
shouldNavigate
:(
BOOL
)
inNavigateApps
canChooseDirectories
:(
BOOL
)
inChooseDirectories
withEnv
:(
JNIEnv
*
)
env
;
withEnv
:(
JNIEnv
*
)
env
;
// Invoked from the main thread
// Invoked from the main thread
...
...
src/macosx/native/sun/awt/CFileDialog.m
浏览文件 @
e3f4887c
...
@@ -43,6 +43,7 @@
...
@@ -43,6 +43,7 @@
mode
:(
jint
)
inMode
mode
:(
jint
)
inMode
multipleMode
:(
BOOL
)
inMultipleMode
multipleMode
:(
BOOL
)
inMultipleMode
shouldNavigate
:(
BOOL
)
inNavigateApps
shouldNavigate
:(
BOOL
)
inNavigateApps
canChooseDirectories
:(
BOOL
)
inChooseDirectories
withEnv
:(
JNIEnv
*
)
env
;
withEnv
:(
JNIEnv
*
)
env
;
{
{
if
(
self
==
[
super
init
])
{
if
(
self
==
[
super
init
])
{
...
@@ -57,6 +58,7 @@
...
@@ -57,6 +58,7 @@
fMode
=
inMode
;
fMode
=
inMode
;
fMultipleMode
=
inMultipleMode
;
fMultipleMode
=
inMultipleMode
;
fNavigateApps
=
inNavigateApps
;
fNavigateApps
=
inNavigateApps
;
fChooseDirectories
=
inChooseDirectories
;
fPanelResult
=
NSCancelButton
;
fPanelResult
=
NSCancelButton
;
}
}
...
@@ -109,7 +111,7 @@
...
@@ -109,7 +111,7 @@
NSOpenPanel
*
openPanel
=
(
NSOpenPanel
*
)
thePanel
;
NSOpenPanel
*
openPanel
=
(
NSOpenPanel
*
)
thePanel
;
[
openPanel
setAllowsMultipleSelection
:
fMultipleMode
];
[
openPanel
setAllowsMultipleSelection
:
fMultipleMode
];
[
openPanel
setCanChooseFiles
:
YES
];
[
openPanel
setCanChooseFiles
:
YES
];
[
openPanel
setCanChooseDirectories
:
NO
];
[
openPanel
setCanChooseDirectories
:
fChooseDirectories
];
[
openPanel
setCanCreateDirectories
:
YES
];
[
openPanel
setCanCreateDirectories
:
YES
];
}
}
...
@@ -182,7 +184,8 @@
...
@@ -182,7 +184,8 @@
JNIEXPORT
jobjectArray
JNICALL
JNIEXPORT
jobjectArray
JNICALL
Java_sun_lwawt_macosx_CFileDialog_nativeRunFileDialog
Java_sun_lwawt_macosx_CFileDialog_nativeRunFileDialog
(
JNIEnv
*
env
,
jobject
peer
,
jstring
title
,
jint
mode
,
jboolean
multipleMode
,
(
JNIEnv
*
env
,
jobject
peer
,
jstring
title
,
jint
mode
,
jboolean
multipleMode
,
jboolean
navigateApps
,
jboolean
hasFilter
,
jstring
directory
,
jstring
file
)
jboolean
navigateApps
,
jboolean
chooseDirectories
,
jboolean
hasFilter
,
jstring
directory
,
jstring
file
)
{
{
jobjectArray
returnValue
=
NULL
;
jobjectArray
returnValue
=
NULL
;
...
@@ -200,6 +203,7 @@ JNF_COCOA_ENTER(env);
...
@@ -200,6 +203,7 @@ JNF_COCOA_ENTER(env);
mode:
mode
mode:
mode
multipleMode:
multipleMode
multipleMode:
multipleMode
shouldNavigate:
navigateApps
shouldNavigate:
navigateApps
canChooseDirectories:
chooseDirectories
withEnv:
env
];
withEnv:
env
];
[
JNFRunLoop
performOnMainThread
:
@selector
(
safeSaveOrLoad
)
[
JNFRunLoop
performOnMainThread
:
@selector
(
safeSaveOrLoad
)
...
...
src/macosx/native/sun/java2d/opengl/CGLGraphicsConfig.m
浏览文件 @
e3f4887c
...
@@ -447,3 +447,20 @@ Java_sun_java2d_opengl_CGLGraphicsConfig_getOGLCapabilities
...
@@ -447,3 +447,20 @@ Java_sun_java2d_opengl_CGLGraphicsConfig_getOGLCapabilities
return
cglinfo
->
context
->
caps
;
return
cglinfo
->
context
->
caps
;
}
}
}
}
JNIEXPORT
jint
JNICALL
Java_sun_java2d_opengl_CGLGraphicsConfig_getMaxTextureSize
(
JNIEnv
*
env
,
jclass
cglgc
)
{
J2dTraceLn
(
J2D_TRACE_INFO
,
"CGLGraphicsConfig_getMaxTextureSize"
);
__block
int
max
=
0
;
[
JNFRunLoop
performOnMainThreadWaiting
:
YES
withBlock
:
^
(){
[
sharedContext
makeCurrentContext
];
j2d_glGetIntegerv
(
GL_MAX_TEXTURE_SIZE
,
&
max
);
}];
return
(
jint
)
max
;
}
src/macosx/native/sun/osxapp/NSApplicationAWT.h
浏览文件 @
e3f4887c
...
@@ -28,7 +28,6 @@
...
@@ -28,7 +28,6 @@
@interface
NSApplicationAWT
:
NSApplication
{
@interface
NSApplicationAWT
:
NSApplication
{
NSString
*
fApplicationName
;
NSString
*
fApplicationName
;
BOOL
fUseDefaultIcon
;
NSWindow
*
eventTransparentWindow
;
NSWindow
*
eventTransparentWindow
;
}
}
...
...
src/macosx/native/sun/osxapp/NSApplicationAWT.m
浏览文件 @
e3f4887c
...
@@ -52,7 +52,6 @@ BOOL postEventDuringEventSynthesis = NO;
...
@@ -52,7 +52,6 @@ BOOL postEventDuringEventSynthesis = NO;
AWT_ASSERT_APPKIT_THREAD
;
AWT_ASSERT_APPKIT_THREAD
;
fApplicationName
=
nil
;
fApplicationName
=
nil
;
fUseDefaultIcon
=
NO
;
// NSApplication will call _RegisterApplication with the application's bundle, but there may not be one.
// NSApplication will call _RegisterApplication with the application's bundle, but there may not be one.
// So, we need to call it ourselves to ensure the app is set up properly.
// So, we need to call it ourselves to ensure the app is set up properly.
...
@@ -147,10 +146,6 @@ AWT_ASSERT_APPKIT_THREAD;
...
@@ -147,10 +146,6 @@ AWT_ASSERT_APPKIT_THREAD;
if
(
appName
!=
NULL
)
{
if
(
appName
!=
NULL
)
{
fApplicationName
=
[
NSString
stringWithUTF8String
:
appName
];
fApplicationName
=
[
NSString
stringWithUTF8String
:
appName
];
unsetenv
(
envVar
);
unsetenv
(
envVar
);
// If this environment variable was set we were launched from the command line, so we
// should use a generic app icon if one wasn't set.
fUseDefaultIcon
=
YES
;
}
}
// If it wasn't specified as an argument, see if it was specified as a system property.
// If it wasn't specified as an argument, see if it was specified as a system property.
...
@@ -171,9 +166,6 @@ AWT_ASSERT_APPKIT_THREAD;
...
@@ -171,9 +166,6 @@ AWT_ASSERT_APPKIT_THREAD;
if
(
lastPeriod
.
location
!=
NSNotFound
)
{
if
(
lastPeriod
.
location
!=
NSNotFound
)
{
fApplicationName
=
[
fApplicationName
substringFromIndex
:
lastPeriod
.
location
+
1
];
fApplicationName
=
[
fApplicationName
substringFromIndex
:
lastPeriod
.
location
+
1
];
}
}
// If this environment variable was set we were launched from the command line, so we
// should use a generic app icon if one wasn't set.
fUseDefaultIcon
=
YES
;
}
}
}
}
...
@@ -266,9 +258,12 @@ AWT_ASSERT_APPKIT_THREAD;
...
@@ -266,9 +258,12 @@ AWT_ASSERT_APPKIT_THREAD;
// If the icon file wasn't specified as an argument and we need to get an icon
// If the icon file wasn't specified as an argument and we need to get an icon
// we'll use the generic java app icon.
// we'll use the generic java app icon.
NSString
*
defaultIconPath
=
[
NSString
stringWithFormat
:
@"%@%@"
,
SHARED_FRAMEWORK_BUNDLE
,
@"/Resources/GenericApp.icns"
];
NSString
*
defaultIconPath
=
[
NSString
stringWithFormat
:
@"%@%@"
,
SHARED_FRAMEWORK_BUNDLE
,
@"/Resources/GenericApp.icns"
];
if
(
fUseDefaultIcon
&&
(
theIconPath
==
nil
))
{
if
(
theIconPath
==
nil
)
{
NSString
*
bundleIcon
=
[[
NSBundle
mainBundle
]
objectForInfoDictionaryKey
:
@"CFBundleIconFile"
];
if
(
bundleIcon
==
nil
)
{
theIconPath
=
defaultIconPath
;
theIconPath
=
defaultIconPath
;
}
}
}
// Set up the dock icon if we have an icon name.
// Set up the dock icon if we have an icon name.
if
(
theIconPath
!=
nil
)
{
if
(
theIconPath
!=
nil
)
{
...
...
src/share/classes/java/awt/Component.java
浏览文件 @
e3f4887c
...
@@ -150,7 +150,7 @@ import sun.util.logging.PlatformLogger;
...
@@ -150,7 +150,7 @@ import sun.util.logging.PlatformLogger;
* import java.awt.event.*;
* import java.awt.event.*;
* import java.io.Serializable;
* import java.io.Serializable;
*
*
* class MyApp java.io.Serializable
* class MyApp
implements
java.io.Serializable
* {
* {
* BigObjectThatShouldNotBeSerializedWithAButton bigOne;
* BigObjectThatShouldNotBeSerializedWithAButton bigOne;
* Button aButton = new Button();
* Button aButton = new Button();
...
...
src/share/classes/java/awt/EventQueue.java
浏览文件 @
e3f4887c
...
@@ -36,6 +36,8 @@ import java.security.AccessController;
...
@@ -36,6 +36,8 @@ import java.security.AccessController;
import
java.security.PrivilegedAction
;
import
java.security.PrivilegedAction
;
import
java.util.EmptyStackException
;
import
java.util.EmptyStackException
;
import
sun.awt.dnd.SunDropTargetEvent
;
import
sun.util.logging.PlatformLogger
;
import
sun.util.logging.PlatformLogger
;
import
sun.awt.AppContext
;
import
sun.awt.AppContext
;
...
@@ -464,7 +466,9 @@ public class EventQueue {
...
@@ -464,7 +466,9 @@ public class EventQueue {
case
MouseEvent
.
MOUSE_MOVED
:
case
MouseEvent
.
MOUSE_MOVED
:
return
MOVE
;
return
MOVE
;
case
MouseEvent
.
MOUSE_DRAGGED
:
case
MouseEvent
.
MOUSE_DRAGGED
:
return
DRAG
;
// Return -1 for SunDropTargetEvent since they are usually synchronous
// and we don't want to skip them by coalescing with MouseEvent or other drag events
return
e
instanceof
SunDropTargetEvent
?
-
1
:
DRAG
;
default
:
default
:
return
e
instanceof
PeerEvent
?
PEER
:
-
1
;
return
e
instanceof
PeerEvent
?
PEER
:
-
1
;
}
}
...
...
src/share/classes/java/beans/PropertyDescriptor.java
浏览文件 @
e3f4887c
...
@@ -657,7 +657,7 @@ public class PropertyDescriptor extends FeatureDescriptor {
...
@@ -657,7 +657,7 @@ public class PropertyDescriptor extends FeatureDescriptor {
throw
new
IntrospectionException
(
"bad write method arg count: "
throw
new
IntrospectionException
(
"bad write method arg count: "
+
writeMethod
);
+
writeMethod
);
}
}
if
(
propertyType
!=
null
&&
propertyType
!=
params
[
0
]
)
{
if
(
propertyType
!=
null
&&
!
params
[
0
].
isAssignableFrom
(
propertyType
)
)
{
throw
new
IntrospectionException
(
"type mismatch between read and write methods"
);
throw
new
IntrospectionException
(
"type mismatch between read and write methods"
);
}
}
propertyType
=
params
[
0
];
propertyType
=
params
[
0
];
...
...
src/share/classes/javax/swing/JTable.java
浏览文件 @
e3f4887c
...
@@ -8590,7 +8590,7 @@ public class JTable extends JComponent implements TableModelListener, Scrollable
...
@@ -8590,7 +8590,7 @@ public class JTable extends JComponent implements TableModelListener, Scrollable
* <code>null</code> if this object is not on the screen
* <code>null</code> if this object is not on the screen
*/
*/
public
Point
getLocationOnScreen
()
{
public
Point
getLocationOnScreen
()
{
if
(
parent
!=
null
)
{
if
(
parent
!=
null
&&
parent
.
isShowing
()
)
{
Point
parentLocation
=
parent
.
getLocationOnScreen
();
Point
parentLocation
=
parent
.
getLocationOnScreen
();
Point
componentLocation
=
getLocation
();
Point
componentLocation
=
getLocation
();
componentLocation
.
translate
(
parentLocation
.
x
,
parentLocation
.
y
);
componentLocation
.
translate
(
parentLocation
.
x
,
parentLocation
.
y
);
...
@@ -9391,7 +9391,7 @@ public class JTable extends JComponent implements TableModelListener, Scrollable
...
@@ -9391,7 +9391,7 @@ public class JTable extends JComponent implements TableModelListener, Scrollable
* <code>null</code> if this object is not on the screen
* <code>null</code> if this object is not on the screen
*/
*/
public
Point
getLocationOnScreen
()
{
public
Point
getLocationOnScreen
()
{
if
(
parent
!=
null
)
{
if
(
parent
!=
null
&&
parent
.
isShowing
()
)
{
Point
parentLocation
=
parent
.
getLocationOnScreen
();
Point
parentLocation
=
parent
.
getLocationOnScreen
();
Point
componentLocation
=
getLocation
();
Point
componentLocation
=
getLocation
();
componentLocation
.
translate
(
parentLocation
.
x
,
parentLocation
.
y
);
componentLocation
.
translate
(
parentLocation
.
x
,
parentLocation
.
y
);
...
...
src/share/classes/sun/awt/TextureSizeConstraining.java
0 → 100644
浏览文件 @
e3f4887c
/*
* 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. Oracle designates this
* particular file as subject to the "Classpath" exception as provided
* by Oracle in the LICENSE file that accompanied this code.
*
* 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.
*/
package
sun.awt
;
/**
* A GraphicsConfiguration implements the TextureSizeConstraining
* interface to indicate that it imposes certain limitations on the
* maximum size of supported textures.
*/
public
interface
TextureSizeConstraining
{
/**
* Returns the maximum width of any texture image.
*/
public
int
getMaxTextureWidth
();
/**
* Returns the maximum height of any texture image.
*/
public
int
getMaxTextureHeight
();
}
test/java
x/swing/JColorChooser/Test4380468
.java
→
test/java
/awt/Frame/HugeFrame/HugeFrame
.java
浏览文件 @
e3f4887c
/*
/*
* Copyright (c) 20
00, 2008
, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 20
12
, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
*
* This code is free software; you can redistribute it and/or modify it
* This code is free software; you can redistribute it and/or modify it
...
@@ -22,19 +22,28 @@
...
@@ -22,19 +22,28 @@
*/
*/
/*
/*
* @test
@test
* @bug 4380468
@bug 7160609
* @summary JColorChooser's HSB panel should display all RGB digits
@summary A window with huge dimensions shouldn't crash JVM
* @author Andrey Pikalev
@author anthony.petrov@oracle.com: area=awt.toplevel
* @run applet/manual=yesno Test4380468.html
@run main HugeFrame
*/
*/
import
java.awt.*
;
public
class
HugeFrame
{
public
static
void
main
(
String
[]
args
)
throws
Exception
{
Frame
f
=
new
Frame
(
"Huge"
);
// 8193+ should already produce a crash, but let's go extreme...
f
.
setBounds
(
10
,
10
,
30000
,
500000
);
f
.
setVisible
(
true
);
import
java.awt.Color
;
// We would crash by now if the bug wasn't fixed
import
javax.swing.JApplet
;
Thread
.
sleep
(
1000
)
;
import
javax.swing.JColorChooser
;
System
.
err
.
println
(
f
.
getBounds
())
;
public
class
Test4380468
extends
JApplet
{
// Cleanup
public
void
init
()
{
f
.
dispose
();
add
(
new
JColorChooser
(
Color
.
GREEN
));
}
}
}
}
test/java/beans/Introspector/Test7189112.java
0 → 100644
浏览文件 @
e3f4887c
/*
* 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.
*/
/*
* @test
* @bug 7189112
* @summary Tests overridden getter
* @author Sergey Malenkov
*/
import
java.beans.IntrospectionException
;
import
java.beans.Introspector
;
import
java.beans.PropertyDescriptor
;
public
class
Test7189112
{
public
static
void
main
(
String
[]
args
)
throws
IntrospectionException
{
for
(
PropertyDescriptor
pd
:
Introspector
.
getBeanInfo
(
MyBean
.
class
).
getPropertyDescriptors
())
{
if
(
pd
.
getName
().
equals
(
"value"
)
&&
(
null
==
pd
.
getWriteMethod
()))
{
throw
new
Error
(
"The property setter is not found"
);
}
}
}
public
static
class
BaseBean
{
private
Object
value
;
public
Object
getValue
()
{
return
this
.
value
;
}
public
void
setValue
(
Object
value
)
{
this
.
value
=
value
;
}
}
public
static
class
MyBean
extends
BaseBean
{
@Override
public
String
getValue
()
{
return
(
String
)
super
.
getValue
();
}
}
}
test/javax/swing/JColorChooser/Test4380468.html
已删除
100644 → 0
浏览文件 @
fba2d1c2
<html>
<body>
1. Click the HSB tab at the ColorChooser.
2. Click in the lower left corner of the gradient palette
in order to select a color such that all three RGB values
are single digit colors (such as 0, 0, 0 or 5, 3, 1).
3. Click another tab, then click back to the HSB tab.
4. Now click the lighter colors that should have
2 and 3 digit RGB values (in the upper right corner).
If all digits of each RGB value are shown then test passes.
If only the last digit of their values are shown then test fails.
<applet
width=
"500"
height=
"400"
code=
"Test4380468.class"
>
</applet>
</body>
</html>
test/javax/swing/JSplitPane/4201995/bug4201995.java
0 → 100644
浏览文件 @
e3f4887c
/*
* 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.
*/
/*
* @test
* @bug 4201995
* @summary Tests that JSplitPane is opaque
* @author Scott Violet
*/
import
javax.swing.*
;
public
class
bug4201995
{
public
static
void
main
(
String
[]
args
)
throws
Exception
{
SwingUtilities
.
invokeAndWait
(
new
Runnable
()
{
@Override
public
void
run
()
{
boolean
expectedOpaqueValue
=
!
"Nimbus"
.
equals
(
UIManager
.
getLookAndFeel
().
getName
());
JSplitPane
sp
=
new
JSplitPane
();
if
(
sp
.
isOpaque
()
!=
expectedOpaqueValue
)
{
throw
new
RuntimeException
(
"JSplitPane has incorrect default opaque value"
);
}
}
});
}
}
test/javax/swing/JTable/4235420/bug4235420.java
0 → 100644
浏览文件 @
e3f4887c
/*
* 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.
*/
/* @test
@bug 4235420
@summary Tests that JTable delays creating Renderers and Editors
@author Peter Zhelezniakov
*/
import
javax.swing.*
;
import
javax.swing.table.TableCellEditor
;
import
javax.swing.table.TableCellRenderer
;
import
java.util.Date
;
import
java.util.HashMap
;
import
java.util.Map
;
public
class
bug4235420
{
public
static
void
main
(
String
[]
argv
)
throws
Exception
{
if
(
"Nimbus"
.
equals
(
UIManager
.
getLookAndFeel
().
getName
()))
{
System
.
out
.
println
(
"The test is skipped for Nimbus"
);
return
;
}
SwingUtilities
.
invokeAndWait
(
new
Runnable
()
{
@Override
public
void
run
()
{
Table
table
=
new
Table
();
table
.
test
();
}
});
}
private
static
class
Table
extends
JTable
{
public
void
test
()
{
// Renderers
Class
[]
rendererClasses
=
{
Object
.
class
,
Number
.
class
,
Date
.
class
,
ImageIcon
.
class
,
Boolean
.
class
};
Map
copy
=
new
HashMap
(
defaultRenderersByColumnClass
);
for
(
Class
rendererClass
:
rendererClasses
)
{
Object
obj
=
copy
.
get
(
rendererClass
);
if
(
obj
instanceof
TableCellRenderer
)
{
throw
new
Error
(
"Failed: TableCellRenderer created for "
+
rendererClass
.
getClass
().
getName
());
}
}
// Editors
Class
[]
editorClasses
=
{
Object
.
class
,
Number
.
class
,
Boolean
.
class
};
copy
=
new
HashMap
(
defaultEditorsByColumnClass
);
for
(
Class
editorClass
:
editorClasses
)
{
Object
obj
=
copy
.
get
(
editorClass
);
if
(
obj
instanceof
TableCellEditor
)
{
throw
new
Error
(
"Failed: TableCellEditor created for "
+
editorClass
.
getClass
().
getName
());
}
}
}
}
}
test/javax/swing/JTable/7188612/JTableAccessibleGetLocationOnScreen.java
0 → 100644
浏览文件 @
e3f4887c
/*
* 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.
*/
/*
* Portions Copyright (c) 2012 IBM Corporation
*/
/* @test
* @bug 7188612
* @summary AccessibleTableHeader and AccessibleJTableCell should stick to
* AccessibleComponent.getLocationOnScreen api.
* @author Frank Ding
*/
import
javax.accessibility.AccessibleComponent
;
import
javax.accessibility.AccessibleTable
;
import
javax.swing.JComponent
;
import
javax.swing.JFrame
;
import
javax.swing.JTable
;
import
javax.swing.SwingUtilities
;
public
class
JTableAccessibleGetLocationOnScreen
{
private
static
JFrame
frame
;
private
static
JTable
table
;
public
static
void
main
(
String
[]
args
)
throws
Exception
{
SwingUtilities
.
invokeAndWait
(
new
Runnable
()
{
@Override
public
void
run
()
{
constructInEDT
();
try
{
assertGetLocation
();
}
finally
{
frame
.
dispose
();
}
}
});
}
private
static
void
constructInEDT
()
{
String
[]
columnNames
=
{
"col1"
,
"col2"
,
};
Object
[][]
data
=
{
{
"row1, col1"
,
"row1, col2"
},
{
"row2, col1"
,
"row2, col2"
},
};
frame
=
new
JFrame
(
"JTable AccessibleTableHeader and AccessibleJTableCell test"
);
frame
.
setDefaultCloseOperation
(
JFrame
.
EXIT_ON_CLOSE
);
table
=
new
JTable
(
data
,
columnNames
);
frame
.
add
(
table
);
frame
.
pack
();
}
private
static
void
assertGetLocation
()
{
// the frame is now invisible
// test getLocationOnScreen() of
// JTable$AccessibleJTable$AccessibleJTableHeaderCell
// and JTable$AccessibleJTable$AccessibleJTableCell
AccessibleTable
accessibleTable
=
(
AccessibleTable
)
table
.
getAccessibleContext
();
AccessibleTable
header
=
accessibleTable
.
getAccessibleColumnHeader
();
AccessibleComponent
accessibleComp1
=
(
AccessibleComponent
)
header
.
getAccessibleAt
(
0
,
0
);
// getLocation() must be null according to its javadoc and no exception
// is thrown
if
(
null
!=
accessibleComp1
.
getLocationOnScreen
())
{
throw
new
RuntimeException
(
"JTable$AccessibleJTable$AccessibleJTableHeaderCell."
+
"getLocation() must be null"
);
}
JComponent
.
AccessibleJComponent
accessibleJComponent
=
(
JComponent
.
AccessibleJComponent
)
table
.
getAccessibleContext
();
AccessibleComponent
accessibleComp2
=
(
AccessibleComponent
)
accessibleJComponent
.
getAccessibleChild
(
3
);
// getLocation() must be null according to its javadoc and no exception
// is thrown
if
(
null
!=
accessibleComp2
.
getLocationOnScreen
())
{
throw
new
RuntimeException
(
"JTable$AccessibleJTable$"
+
"AccessibleJTableCell.getLocation() must be null"
);
}
}
}
test/tools/launcher/RunpathTest.java
0 → 100644
浏览文件 @
e3f4887c
/*
* 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.
*/
/*
* @test
* @bug 7190813
* @summary Check for extended RPATHs on *nixes
* @compile -XDignore.symbol.file RunpathTest.java
* @run main RunpathTest
* @author ksrini
*/
import
java.io.File
;
public
class
RunpathTest
extends
TestHelper
{
final
String
elfreaderCmd
;
RunpathTest
()
{
elfreaderCmd
=
findElfReader
();
}
final
String
findElfReader
()
{
String
[]
paths
=
{
"/bin"
,
"/sbin"
,
"/usr/bin"
,
"/usr/sbin"
,
"/usr/ccs/bin"
};
final
String
cmd
=
isSolaris
?
"elfdump"
:
"readelf"
;
for
(
String
x
:
paths
)
{
File
p
=
new
File
(
x
);
File
e
=
new
File
(
p
,
cmd
);
if
(
e
.
canExecute
())
{
return
e
.
getAbsolutePath
();
}
}
System
.
err
.
println
(
"Warning: no suitable elf reader!"
);
return
null
;
}
void
elfCheck
(
String
javacmd
,
String
expectedRpath
)
{
final
TestResult
tr
=
doExec
(
elfreaderCmd
,
"-d"
,
javacmd
);
if
(!
tr
.
matches
(
expectedRpath
))
{
System
.
out
.
println
(
tr
);
throw
new
RuntimeException
(
"FAILED: RPATH strings "
+
expectedRpath
+
" not found in "
+
javaCmd
);
}
System
.
out
.
println
(
javacmd
+
" contains expected RPATHS"
);
}
void
testRpath
()
{
if
(
isDualMode
&&
is64Bit
)
{
String
expectedRpath
=
".*RPATH.*\\$ORIGIN/../../lib/"
+
getJreArch
()
+
":\\$ORIGIN/../../jre/lib/"
+
getJreArch
()
+
".*"
;
elfCheck
(
java64Cmd
,
expectedRpath
);
}
else
{
String
expectedRpath
=
".*RPATH.*\\$ORIGIN/../lib/"
+
getJreArch
()
+
":\\$ORIGIN/../jre/lib/"
+
getJreArch
()
+
".*"
;
elfCheck
(
javaCmd
,
expectedRpath
);
}
}
public
static
void
main
(
String
...
args
)
throws
Exception
{
if
(
isSolaris
||
isLinux
)
{
RunpathTest
rp
=
new
RunpathTest
();
rp
.
testRpath
();
}
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录