Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
10f688e8
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看板
提交
10f688e8
编写于
10月 23, 2013
作者:
M
malenkov
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
8026797: Enhance data transfers
Reviewed-by: art, skoivu
上级
28e4321a
变更
6
隐藏空白更改
内联
并排
Showing
6 changed file
with
35 addition
and
52 deletion
+35
-52
src/macosx/classes/sun/lwawt/macosx/CClipboard.java
src/macosx/classes/sun/lwawt/macosx/CClipboard.java
+1
-1
src/share/classes/java/awt/datatransfer/SystemFlavorMap.java
src/share/classes/java/awt/datatransfer/SystemFlavorMap.java
+24
-40
src/share/classes/sun/awt/datatransfer/ClipboardTransferable.java
...e/classes/sun/awt/datatransfer/ClipboardTransferable.java
+1
-1
src/share/classes/sun/awt/datatransfer/SunClipboard.java
src/share/classes/sun/awt/datatransfer/SunClipboard.java
+6
-6
src/solaris/classes/sun/awt/X11/XClipboard.java
src/solaris/classes/sun/awt/X11/XClipboard.java
+2
-2
src/windows/classes/sun/awt/windows/WClipboard.java
src/windows/classes/sun/awt/windows/WClipboard.java
+1
-2
未找到文件。
src/macosx/classes/sun/lwawt/macosx/CClipboard.java
浏览文件 @
10f688e8
...
...
@@ -53,7 +53,7 @@ public class CClipboard extends SunClipboard {
}
protected
void
setContentsNative
(
Transferable
contents
)
{
FlavorTable
flavorMap
=
getDefaultFlavorTable
();
// Don't use delayed Clipboard rendering for the Transferable's data.
// If we did that, we would call Transferable.getTransferData on
// the Toolkit thread, which is a security hole.
...
...
src/share/classes/java/awt/datatransfer/SystemFlavorMap.java
浏览文件 @
10f688e8
...
...
@@ -40,13 +40,12 @@ import java.net.MalformedURLException;
import
java.util.ArrayList
;
import
java.util.HashMap
;
import
java.util.HashSet
;
import
java.util.Iterator
;
import
java.util.LinkedHashSet
;
import
java.util.List
;
import
java.util.Map
;
import
java.util.Set
;
import
java.util.WeakHashMap
;
import
sun.awt.AppContext
;
import
sun.awt.datatransfer.DataTransferer
;
/**
...
...
@@ -67,10 +66,7 @@ public final class SystemFlavorMap implements FlavorMap, FlavorTable {
*/
private
static
String
JavaMIME
=
"JAVA_DATAFLAVOR:"
;
/**
* System singleton which maps a thread's ClassLoader to a SystemFlavorMap.
*/
private
static
final
WeakHashMap
<
ClassLoader
,
FlavorMap
>
flavorMaps
=
new
WeakHashMap
<>();
private
static
final
Object
FLAVOR_MAP_KEY
=
new
Object
();
/**
* Copied from java.util.Properties.
...
...
@@ -184,22 +180,12 @@ public final class SystemFlavorMap implements FlavorMap, FlavorTable {
* Returns the default FlavorMap for this thread's ClassLoader.
*/
public
static
FlavorMap
getDefaultFlavorMap
()
{
ClassLoader
contextClassLoader
=
Thread
.
currentThread
().
getContextClassLoader
();
if
(
contextClassLoader
==
null
)
{
contextClassLoader
=
ClassLoader
.
getSystemClassLoader
();
}
FlavorMap
fm
;
synchronized
(
flavorMaps
)
{
fm
=
flavorMaps
.
get
(
contextClassLoader
);
if
(
fm
==
null
)
{
fm
=
new
SystemFlavorMap
();
flavorMaps
.
put
(
contextClassLoader
,
fm
);
}
AppContext
context
=
AppContext
.
getAppContext
();
FlavorMap
fm
=
(
FlavorMap
)
context
.
get
(
FLAVOR_MAP_KEY
);
if
(
fm
==
null
)
{
fm
=
new
SystemFlavorMap
();
context
.
put
(
FLAVOR_MAP_KEY
,
fm
);
}
return
fm
;
}
...
...
@@ -240,26 +226,11 @@ public final class SystemFlavorMap implements FlavorMap, FlavorTable {
}
});
BufferedReader
flavormapURL
=
String
url
=
java
.
security
.
AccessController
.
doPrivileged
(
new
java
.
security
.
PrivilegedAction
<
BufferedReader
>()
{
public
BufferedReader
run
()
{
String
url
=
Toolkit
.
getProperty
(
"AWT.DnD.flavorMapFileURL"
,
null
);
if
(
url
==
null
)
{
return
null
;
}
try
{
return
new
BufferedReader
(
new
InputStreamReader
(
new
URL
(
url
).
openStream
(),
"ISO-8859-1"
));
}
catch
(
MalformedURLException
e
)
{
System
.
err
.
println
(
"MalformedURLException:"
+
e
+
" while reading AWT.DnD.flavorMapFileURL:"
+
url
);
}
catch
(
IOException
e
)
{
System
.
err
.
println
(
"IOException:"
+
e
+
" while reading AWT.DnD.flavorMapFileURL:"
+
url
);
}
return
null
;
new
java
.
security
.
PrivilegedAction
<
String
>()
{
public
String
run
()
{
return
Toolkit
.
getProperty
(
"AWT.DnD.flavorMapFileURL"
,
null
);
}
});
...
...
@@ -271,6 +242,19 @@ public final class SystemFlavorMap implements FlavorMap, FlavorTable {
}
}
BufferedReader
flavormapURL
=
null
;
if
(
url
!=
null
)
{
try
{
flavormapURL
=
new
BufferedReader
(
new
InputStreamReader
(
new
URL
(
url
).
openStream
(),
"ISO-8859-1"
));
}
catch
(
MalformedURLException
e
)
{
System
.
err
.
println
(
"MalformedURLException:"
+
e
+
" while reading AWT.DnD.flavorMapFileURL:"
+
url
);
}
catch
(
IOException
e
)
{
System
.
err
.
println
(
"IOException:"
+
e
+
" while reading AWT.DnD.flavorMapFileURL:"
+
url
);
}
catch
(
SecurityException
e
)
{
// ignored
}
}
if
(
flavormapURL
!=
null
)
{
try
{
parseAndStoreReader
(
flavormapURL
);
...
...
src/share/classes/sun/awt/datatransfer/ClipboardTransferable.java
浏览文件 @
10f688e8
...
...
@@ -87,7 +87,7 @@ public class ClipboardTransferable implements Transferable {
HashMap
cached_data
=
new
HashMap
(
formats
.
length
,
1.0f
);
Map
flavorsForFormats
=
DataTransferer
.
getInstance
().
getFlavorsForFormats
(
formats
,
SunClipboard
.
flavorMap
);
getFlavorsForFormats
(
formats
,
SunClipboard
.
getDefaultFlavorTable
()
);
for
(
Iterator
iter
=
flavorsForFormats
.
keySet
().
iterator
();
iter
.
hasNext
();
)
{
...
...
src/share/classes/sun/awt/datatransfer/SunClipboard.java
浏览文件 @
10f688e8
...
...
@@ -64,9 +64,6 @@ import sun.awt.EventListenerAggregate;
public
abstract
class
SunClipboard
extends
Clipboard
implements
PropertyChangeListener
{
public
static
final
FlavorTable
flavorMap
=
(
FlavorTable
)
SystemFlavorMap
.
getDefaultFlavorMap
();
private
AppContext
contentsContext
=
null
;
private
final
Object
CLIPBOARD_FLAVOR_LISTENER_KEY
;
...
...
@@ -172,7 +169,7 @@ public abstract class SunClipboard extends Clipboard
long
[]
formats
=
getClipboardFormatsOpenClose
();
return
DataTransferer
.
getInstance
().
getFlavorsForFormatsAsArray
(
formats
,
flavorMap
);
getFlavorsForFormatsAsArray
(
formats
,
getDefaultFlavorTable
()
);
}
/**
...
...
@@ -218,7 +215,7 @@ public abstract class SunClipboard extends Clipboard
long
[]
formats
=
getClipboardFormats
();
Long
lFormat
=
(
Long
)
DataTransferer
.
getInstance
().
getFlavorsForFormats
(
formats
,
flavorMap
).
get
(
flavor
);
getFlavorsForFormats
(
formats
,
getDefaultFlavorTable
()
).
get
(
flavor
);
if
(
lFormat
==
null
)
{
throw
new
UnsupportedFlavorException
(
flavor
);
...
...
@@ -349,7 +346,7 @@ public abstract class SunClipboard extends Clipboard
private
static
Set
formatArrayAsDataFlavorSet
(
long
[]
formats
)
{
return
(
formats
==
null
)
?
null
:
DataTransferer
.
getInstance
().
getFlavorsForFormatsAsSet
(
formats
,
flavorMap
);
getFlavorsForFormatsAsSet
(
formats
,
getDefaultFlavorTable
()
);
}
...
...
@@ -469,4 +466,7 @@ public abstract class SunClipboard extends Clipboard
}
}
public
static
FlavorTable
getDefaultFlavorTable
()
{
return
(
FlavorTable
)
SystemFlavorMap
.
getDefaultFlavorMap
();
}
}
src/solaris/classes/sun/awt/X11/XClipboard.java
浏览文件 @
10f688e8
...
...
@@ -86,7 +86,7 @@ public final class XClipboard extends SunClipboard implements OwnershipListener
protected
synchronized
void
setContentsNative
(
Transferable
contents
)
{
SortedMap
<
Long
,
DataFlavor
>
formatMap
=
DataTransferer
.
getInstance
().
getFormatsForTransferable
(
contents
,
DataTransferer
.
adaptFlavorMap
(
flavorMap
));
(
contents
,
DataTransferer
.
adaptFlavorMap
(
getDefaultFlavorTable
()
));
long
[]
formats
=
DataTransferer
.
keysToLongArray
(
formatMap
);
if
(!
selection
.
setOwner
(
contents
,
formatMap
,
formats
,
...
...
@@ -125,7 +125,7 @@ public final class XClipboard extends SunClipboard implements OwnershipListener
private
void
checkChangeHere
(
Transferable
contents
)
{
if
(
areFlavorListenersRegistered
())
{
checkChange
(
DataTransferer
.
getInstance
().
getFormatsForTransferableAsArray
(
contents
,
flavorMap
));
getFormatsForTransferableAsArray
(
contents
,
getDefaultFlavorTable
()
));
}
}
...
...
src/windows/classes/sun/awt/windows/WClipboard.java
浏览文件 @
10f688e8
...
...
@@ -63,7 +63,6 @@ public class WClipboard extends SunClipboard {
}
protected
void
setContentsNative
(
Transferable
contents
)
{
// Don't use delayed Clipboard rendering for the Transferable's data.
// If we did that, we would call Transferable.getTransferData on
// the Toolkit thread, which is a security hole.
...
...
@@ -72,7 +71,7 @@ public class WClipboard extends SunClipboard {
// translated. Then, for each format, translate the data and post
// it to the Clipboard.
Map
<
Long
,
DataFlavor
>
formatMap
=
WDataTransferer
.
getInstance
().
getFormatsForTransferable
(
contents
,
flavorMap
);
getFormatsForTransferable
(
contents
,
getDefaultFlavorTable
()
);
openClipboard
(
this
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录