Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
05217614
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看板
提交
05217614
编写于
10月 07, 2008
作者:
D
dav
浏览文件
操作
浏览文件
下载
差异文件
Merge
上级
b5c7d8c2
34cbf65b
变更
6
隐藏空白更改
内联
并排
Showing
6 changed file
with
111 addition
and
0 deletion
+111
-0
make/sun/xawt/mapfile-vers
make/sun/xawt/mapfile-vers
+1
-0
src/solaris/classes/sun/awt/X11/XKeysym.java
src/solaris/classes/sun/awt/X11/XKeysym.java
+14
-0
src/solaris/classes/sun/awt/X11/XToolkit.java
src/solaris/classes/sun/awt/X11/XToolkit.java
+74
-0
src/solaris/classes/sun/awt/X11/XlibWrapper.java
src/solaris/classes/sun/awt/X11/XlibWrapper.java
+1
-0
src/solaris/classes/sun/awt/X11/keysym2ucs.h
src/solaris/classes/sun/awt/X11/keysym2ucs.h
+14
-0
src/solaris/native/sun/xawt/XlibWrapper.c
src/solaris/native/sun/xawt/XlibWrapper.c
+7
-0
未找到文件。
make/sun/xawt/mapfile-vers
浏览文件 @
05217614
...
@@ -289,6 +289,7 @@ SUNWprivate_1.1 {
...
@@ -289,6 +289,7 @@ SUNWprivate_1.1 {
Java_sun_awt_X11_XlibWrapper_XGetIconSizes;
Java_sun_awt_X11_XlibWrapper_XGetIconSizes;
Java_sun_awt_X11_XlibWrapper_XKeycodeToKeysym;
Java_sun_awt_X11_XlibWrapper_XKeycodeToKeysym;
Java_sun_awt_X11_XlibWrapper_XKeysymToKeycode;
Java_sun_awt_X11_XlibWrapper_XKeysymToKeycode;
Java_sun_awt_X11_XlibWrapper_XQueryKeymap;
Java_sun_awt_X11_XlibWrapper_XGetModifierMapping;
Java_sun_awt_X11_XlibWrapper_XGetModifierMapping;
Java_sun_awt_X11_XlibWrapper_XFreeModifiermap;
Java_sun_awt_X11_XlibWrapper_XFreeModifiermap;
Java_sun_awt_X11_XlibWrapper_XChangeActivePointerGrab;
Java_sun_awt_X11_XlibWrapper_XChangeActivePointerGrab;
...
...
src/solaris/classes/sun/awt/X11/XKeysym.java
浏览文件 @
05217614
...
@@ -63,6 +63,8 @@ public class XKeysym {
...
@@ -63,6 +63,8 @@ public class XKeysym {
// TODO: or not to do: add reverse lookup javakeycode2keysym,
// TODO: or not to do: add reverse lookup javakeycode2keysym,
// for robot only it seems to me. After that, we can remove lookup table
// for robot only it seems to me. After that, we can remove lookup table
// from XWindow.c altogether.
// from XWindow.c altogether.
// Another use for reverse lookup: query keyboard state, for some keys.
static
Hashtable
<
Integer
,
Long
>
javaKeycode2KeysymHash
=
new
Hashtable
<
Integer
,
Long
>();
static
long
keysym_lowercase
=
unsafe
.
allocateMemory
(
Native
.
getLongSize
());
static
long
keysym_lowercase
=
unsafe
.
allocateMemory
(
Native
.
getLongSize
());
static
long
keysym_uppercase
=
unsafe
.
allocateMemory
(
Native
.
getLongSize
());
static
long
keysym_uppercase
=
unsafe
.
allocateMemory
(
Native
.
getLongSize
());
public
static
char
convertKeysym
(
long
ks
,
int
state
)
{
public
static
char
convertKeysym
(
long
ks
,
int
state
)
{
...
@@ -196,6 +198,10 @@ public class XKeysym {
...
@@ -196,6 +198,10 @@ public class XKeysym {
Keysym2JavaKeycode
jkc
=
getJavaKeycode
(
ev
);
Keysym2JavaKeycode
jkc
=
getJavaKeycode
(
ev
);
return
jkc
==
null
?
java
.
awt
.
event
.
KeyEvent
.
VK_UNDEFINED
:
jkc
.
getJavaKeycode
();
return
jkc
==
null
?
java
.
awt
.
event
.
KeyEvent
.
VK_UNDEFINED
:
jkc
.
getJavaKeycode
();
}
}
static
long
javaKeycode2Keysym
(
int
jkey
)
{
Long
ks
=
javaKeycode2KeysymHash
.
get
(
jkey
);
return
(
ks
==
null
?
0
:
ks
.
longValue
());
}
/**
/**
Return keysym derived from a keycode and modifiers.
Return keysym derived from a keycode and modifiers.
Usually an input method does this. However non-system input methods (e.g. Java IMs) do not.
Usually an input method does this. However non-system input methods (e.g. Java IMs) do not.
...
@@ -1583,6 +1589,14 @@ public class XKeysym {
...
@@ -1583,6 +1589,14 @@ public class XKeysym {
keysym2JavaKeycodeHash
.
put
(
Long
.
valueOf
(
XKeySymConstants
.
hpXK_mute_asciitilde
),
new
Keysym2JavaKeycode
(
java
.
awt
.
event
.
KeyEvent
.
VK_DEAD_TILDE
,
java
.
awt
.
event
.
KeyEvent
.
KEY_LOCATION_STANDARD
));
keysym2JavaKeycodeHash
.
put
(
Long
.
valueOf
(
XKeySymConstants
.
hpXK_mute_asciitilde
),
new
Keysym2JavaKeycode
(
java
.
awt
.
event
.
KeyEvent
.
VK_DEAD_TILDE
,
java
.
awt
.
event
.
KeyEvent
.
KEY_LOCATION_STANDARD
));
keysym2JavaKeycodeHash
.
put
(
Long
.
valueOf
(
XConstants
.
NoSymbol
),
new
Keysym2JavaKeycode
(
java
.
awt
.
event
.
KeyEvent
.
VK_UNDEFINED
,
java
.
awt
.
event
.
KeyEvent
.
KEY_LOCATION_UNKNOWN
));
keysym2JavaKeycodeHash
.
put
(
Long
.
valueOf
(
XConstants
.
NoSymbol
),
new
Keysym2JavaKeycode
(
java
.
awt
.
event
.
KeyEvent
.
VK_UNDEFINED
,
java
.
awt
.
event
.
KeyEvent
.
KEY_LOCATION_UNKNOWN
));
/* Reverse search of keysym by keycode. */
/* Add keyboard locking codes. */
javaKeycode2KeysymHash
.
put
(
java
.
awt
.
event
.
KeyEvent
.
VK_CAPS_LOCK
,
XKeySymConstants
.
XK_Caps_Lock
);
javaKeycode2KeysymHash
.
put
(
java
.
awt
.
event
.
KeyEvent
.
VK_NUM_LOCK
,
XKeySymConstants
.
XK_Num_Lock
);
javaKeycode2KeysymHash
.
put
(
java
.
awt
.
event
.
KeyEvent
.
VK_SCROLL_LOCK
,
XKeySymConstants
.
XK_Scroll_Lock
);
javaKeycode2KeysymHash
.
put
(
java
.
awt
.
event
.
KeyEvent
.
VK_KANA_LOCK
,
XKeySymConstants
.
XK_Kana_Lock
);
};
};
}
}
src/solaris/classes/sun/awt/X11/XToolkit.java
浏览文件 @
05217614
...
@@ -27,6 +27,7 @@ package sun.awt.X11;
...
@@ -27,6 +27,7 @@ package sun.awt.X11;
import
java.awt.*
;
import
java.awt.*
;
import
java.awt.event.InputEvent
;
import
java.awt.event.InputEvent
;
import
java.awt.event.MouseEvent
;
import
java.awt.event.MouseEvent
;
import
java.awt.event.KeyEvent
;
import
java.awt.datatransfer.Clipboard
;
import
java.awt.datatransfer.Clipboard
;
import
java.awt.dnd.DragSource
;
import
java.awt.dnd.DragSource
;
import
java.awt.dnd.DragGestureListener
;
import
java.awt.dnd.DragGestureListener
;
...
@@ -1102,6 +1103,19 @@ public final class XToolkit extends UNIXToolkit implements Runnable {
...
@@ -1102,6 +1103,19 @@ public final class XToolkit extends UNIXToolkit implements Runnable {
public
Map
mapInputMethodHighlight
(
InputMethodHighlight
highlight
)
{
public
Map
mapInputMethodHighlight
(
InputMethodHighlight
highlight
)
{
return
XInputMethod
.
mapInputMethodHighlight
(
highlight
);
return
XInputMethod
.
mapInputMethodHighlight
(
highlight
);
}
}
@Override
public
boolean
getLockingKeyState
(
int
key
)
{
if
(!
(
key
==
KeyEvent
.
VK_CAPS_LOCK
||
key
==
KeyEvent
.
VK_NUM_LOCK
||
key
==
KeyEvent
.
VK_SCROLL_LOCK
||
key
==
KeyEvent
.
VK_KANA_LOCK
))
{
throw
new
IllegalArgumentException
(
"invalid key for Toolkit.getLockingKeyState"
);
}
awtLock
();
try
{
return
getModifierState
(
key
);
}
finally
{
awtUnlock
();
}
}
public
Clipboard
getSystemClipboard
()
{
public
Clipboard
getSystemClipboard
()
{
SecurityManager
security
=
System
.
getSecurityManager
();
SecurityManager
security
=
System
.
getSecurityManager
();
...
@@ -1569,6 +1583,66 @@ public final class XToolkit extends UNIXToolkit implements Runnable {
...
@@ -1569,6 +1583,66 @@ public final class XToolkit extends UNIXToolkit implements Runnable {
awtUnlock
();
awtUnlock
();
}
}
}
}
static
boolean
getModifierState
(
int
jkc
)
{
int
iKeyMask
=
0
;
long
ks
=
XKeysym
.
javaKeycode2Keysym
(
jkc
);
int
kc
=
XlibWrapper
.
XKeysymToKeycode
(
getDisplay
(),
ks
);
if
(
kc
==
0
)
{
return
false
;
}
awtLock
();
try
{
XModifierKeymap
modmap
=
new
XModifierKeymap
(
XlibWrapper
.
XGetModifierMapping
(
getDisplay
()));
int
nkeys
=
modmap
.
get_max_keypermod
();
long
map_ptr
=
modmap
.
get_modifiermap
();
for
(
int
k
=
0
;
k
<
8
;
k
++
)
{
for
(
int
i
=
0
;
i
<
nkeys
;
++
i
)
{
int
keycode
=
Native
.
getUByte
(
map_ptr
,
k
*
nkeys
+
i
);
if
(
keycode
==
0
)
{
continue
;
// ignore zero keycode
}
if
(
kc
==
keycode
)
{
iKeyMask
=
1
<<
k
;
break
;
}
}
if
(
iKeyMask
!=
0
)
{
break
;
}
}
XlibWrapper
.
XFreeModifiermap
(
modmap
.
pData
);
if
(
iKeyMask
==
0
)
{
return
false
;
}
// Now we know to which modifier is assigned the keycode
// correspondent to the keysym correspondent to the java
// keycode. We are going to check a state of this modifier.
// If a modifier is a weird one, we cannot help it.
long
window
=
0
;
try
{
// get any application window
window
=
((
Long
)(
winMap
.
firstKey
())).
longValue
();
}
catch
(
NoSuchElementException
nex
)
{
// get root window
window
=
getDefaultRootWindow
();
}
boolean
res
=
XlibWrapper
.
XQueryPointer
(
getDisplay
(),
window
,
XlibWrapper
.
larg1
,
//root
XlibWrapper
.
larg2
,
//child
XlibWrapper
.
larg3
,
//root_x
XlibWrapper
.
larg4
,
//root_y
XlibWrapper
.
larg5
,
//child_x
XlibWrapper
.
larg6
,
//child_y
XlibWrapper
.
larg7
);
//mask
int
mask
=
Native
.
getInt
(
XlibWrapper
.
larg7
);
return
((
mask
&
iKeyMask
)
!=
0
);
}
finally
{
awtUnlock
();
}
}
/* Assign meaning - alt, meta, etc. - to X modifiers mod1 ... mod5.
/* Assign meaning - alt, meta, etc. - to X modifiers mod1 ... mod5.
* Only consider primary symbols on keycodes attached to modifiers.
* Only consider primary symbols on keycodes attached to modifiers.
...
...
src/solaris/classes/sun/awt/X11/XlibWrapper.java
浏览文件 @
05217614
...
@@ -485,6 +485,7 @@ static native String XSetLocaleModifiers(String modifier_list);
...
@@ -485,6 +485,7 @@ static native String XSetLocaleModifiers(String modifier_list);
static
native
int
XdbeEndIdiom
(
long
display
);
static
native
int
XdbeEndIdiom
(
long
display
);
static
native
int
XdbeSwapBuffers
(
long
display
,
long
swap_info
,
int
num_windows
);
static
native
int
XdbeSwapBuffers
(
long
display
,
long
swap_info
,
int
num_windows
);
static
native
void
XQueryKeymap
(
long
display
,
long
vector
);
static
native
long
XKeycodeToKeysym
(
long
display
,
int
keycode
,
int
index
);
static
native
long
XKeycodeToKeysym
(
long
display
,
int
keycode
,
int
index
);
static
native
int
XKeysymToKeycode
(
long
display
,
long
keysym
);
static
native
int
XKeysymToKeycode
(
long
display
,
long
keysym
);
...
...
src/solaris/classes/sun/awt/X11/keysym2ucs.h
浏览文件 @
05217614
...
@@ -101,6 +101,8 @@ tojava static Hashtable<Long, Long> uppercaseHash = new Hashtable<Long, Long
...
@@ -101,6 +101,8 @@ tojava static Hashtable<Long, Long> uppercaseHash = new Hashtable<Long, Long
tojava
// TODO: or not to do: add reverse lookup javakeycode2keysym,
tojava
// TODO: or not to do: add reverse lookup javakeycode2keysym,
tojava
// for robot only it seems to me. After that, we can remove lookup table
tojava
// for robot only it seems to me. After that, we can remove lookup table
tojava
// from XWindow.c altogether.
tojava
// from XWindow.c altogether.
tojava
// Another use for reverse lookup: query keyboard state, for some keys.
tojava
static
Hashtable
<
Integer
,
Long
>
javaKeycode2KeysymHash
=
new
Hashtable
<
Integer
,
Long
>
();
tojava
static
long
keysym_lowercase
=
unsafe
.
allocateMemory
(
Native
.
getLongSize
());
tojava
static
long
keysym_lowercase
=
unsafe
.
allocateMemory
(
Native
.
getLongSize
());
tojava
static
long
keysym_uppercase
=
unsafe
.
allocateMemory
(
Native
.
getLongSize
());
tojava
static
long
keysym_uppercase
=
unsafe
.
allocateMemory
(
Native
.
getLongSize
());
tojava
public
static
char
convertKeysym
(
long
ks
,
int
state
)
{
tojava
public
static
char
convertKeysym
(
long
ks
,
int
state
)
{
...
@@ -234,6 +236,10 @@ tojava static int getJavaKeycodeOnly( XKeyEvent ev ) {
...
@@ -234,6 +236,10 @@ tojava static int getJavaKeycodeOnly( XKeyEvent ev ) {
tojava
Keysym2JavaKeycode
jkc
=
getJavaKeycode
(
ev
);
tojava
Keysym2JavaKeycode
jkc
=
getJavaKeycode
(
ev
);
tojava
return
jkc
==
null
?
java
.
awt
.
event
.
KeyEvent
.
VK_UNDEFINED
:
jkc
.
getJavaKeycode
();
tojava
return
jkc
==
null
?
java
.
awt
.
event
.
KeyEvent
.
VK_UNDEFINED
:
jkc
.
getJavaKeycode
();
tojava
}
tojava
}
tojava
static
long
javaKeycode2Keysym
(
int
jkey
)
{
tojava
Long
ks
=
javaKeycode2KeysymHash
.
get
(
jkey
);
tojava
return
(
ks
==
null
?
0
:
ks
.
longValue
());
tojava
}
tojava
/**
tojava
/**
tojava Return keysym derived from a keycode and modifiers.
tojava Return keysym derived from a keycode and modifiers.
tojava Usually an input method does this. However non-system input methods (e.g. Java IMs) do not.
tojava Usually an input method does this. However non-system input methods (e.g. Java IMs) do not.
...
@@ -2634,6 +2640,14 @@ tojava keysym2JavaKeycodeHash.put( Long.valueOf(XKeySymConstants.hpXK_mu
...
@@ -2634,6 +2640,14 @@ tojava keysym2JavaKeycodeHash.put( Long.valueOf(XKeySymConstants.hpXK_mu
tojava
keysym2JavaKeycodeHash
.
put
(
Long
.
valueOf
(
XKeySymConstants
.
hpXK_mute_asciitilde
),
new
Keysym2JavaKeycode
(
java
.
awt
.
event
.
KeyEvent
.
VK_DEAD_TILDE
,
java
.
awt
.
event
.
KeyEvent
.
KEY_LOCATION_STANDARD
));
tojava
keysym2JavaKeycodeHash
.
put
(
Long
.
valueOf
(
XKeySymConstants
.
hpXK_mute_asciitilde
),
new
Keysym2JavaKeycode
(
java
.
awt
.
event
.
KeyEvent
.
VK_DEAD_TILDE
,
java
.
awt
.
event
.
KeyEvent
.
KEY_LOCATION_STANDARD
));
tojava
tojava
tojava
keysym2JavaKeycodeHash
.
put
(
Long
.
valueOf
(
XConstants
.
NoSymbol
),
new
Keysym2JavaKeycode
(
java
.
awt
.
event
.
KeyEvent
.
VK_UNDEFINED
,
java
.
awt
.
event
.
KeyEvent
.
KEY_LOCATION_UNKNOWN
));
tojava
keysym2JavaKeycodeHash
.
put
(
Long
.
valueOf
(
XConstants
.
NoSymbol
),
new
Keysym2JavaKeycode
(
java
.
awt
.
event
.
KeyEvent
.
VK_UNDEFINED
,
java
.
awt
.
event
.
KeyEvent
.
KEY_LOCATION_UNKNOWN
));
tojava
tojava
/* Reverse search of keysym by keycode. */
tojava
tojava
/* Add keyboard locking codes. */
tojava
javaKeycode2KeysymHash
.
put
(
java
.
awt
.
event
.
KeyEvent
.
VK_CAPS_LOCK
,
XKeySymConstants
.
XK_Caps_Lock
);
tojava
javaKeycode2KeysymHash
.
put
(
java
.
awt
.
event
.
KeyEvent
.
VK_NUM_LOCK
,
XKeySymConstants
.
XK_Num_Lock
);
tojava
javaKeycode2KeysymHash
.
put
(
java
.
awt
.
event
.
KeyEvent
.
VK_SCROLL_LOCK
,
XKeySymConstants
.
XK_Scroll_Lock
);
tojava
javaKeycode2KeysymHash
.
put
(
java
.
awt
.
event
.
KeyEvent
.
VK_KANA_LOCK
,
XKeySymConstants
.
XK_Kana_Lock
);
tojava
};
tojava
};
tojava
tojava
tojava
}
tojava
}
src/solaris/native/sun/xawt/XlibWrapper.c
浏览文件 @
05217614
...
@@ -1641,6 +1641,13 @@ JNIEXPORT jint JNICALL Java_sun_awt_X11_XlibWrapper_XdbeSwapBuffers
...
@@ -1641,6 +1641,13 @@ JNIEXPORT jint JNICALL Java_sun_awt_X11_XlibWrapper_XdbeSwapBuffers
AWT_CHECK_HAVE_LOCK
();
AWT_CHECK_HAVE_LOCK
();
return
XdbeSwapBuffers
((
Display
*
)
jlong_to_ptr
(
display
),
(
XdbeSwapInfo
*
)
jlong_to_ptr
(
swap_info
),
num_windows
);
return
XdbeSwapBuffers
((
Display
*
)
jlong_to_ptr
(
display
),
(
XdbeSwapInfo
*
)
jlong_to_ptr
(
swap_info
),
num_windows
);
}
}
JNIEXPORT
void
JNICALL
Java_sun_awt_X11_XlibWrapper_XQueryKeymap
(
JNIEnv
*
env
,
jclass
clazz
,
jlong
display
,
jlong
vector
)
{
AWT_CHECK_HAVE_LOCK
();
XQueryKeymap
(
(
Display
*
)
jlong_to_ptr
(
display
),
(
char
*
)
jlong_to_ptr
(
vector
));
}
JNIEXPORT
jlong
JNICALL
JNIEXPORT
jlong
JNICALL
Java_sun_awt_X11_XlibWrapper_XKeycodeToKeysym
(
JNIEnv
*
env
,
jclass
clazz
,
Java_sun_awt_X11_XlibWrapper_XKeycodeToKeysym
(
JNIEnv
*
env
,
jclass
clazz
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录