Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
bf4e9501
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看板
提交
bf4e9501
编写于
11月 18, 2009
作者:
L
lana
浏览文件
操作
浏览文件
下载
差异文件
Merge
上级
bb553e5e
c1a7cd13
变更
46
展开全部
隐藏空白更改
内联
并排
Showing
46 changed file
with
2662 addition
and
680 deletion
+2662
-680
make/sun/javazic/tzdata/VERSION
make/sun/javazic/tzdata/VERSION
+1
-1
make/sun/javazic/tzdata/antarctica
make/sun/javazic/tzdata/antarctica
+26
-3
make/sun/javazic/tzdata/asia
make/sun/javazic/tzdata/asia
+207
-18
make/sun/javazic/tzdata/australasia
make/sun/javazic/tzdata/australasia
+47
-1
make/sun/javazic/tzdata/europe
make/sun/javazic/tzdata/europe
+35
-1
make/sun/javazic/tzdata/southamerica
make/sun/javazic/tzdata/southamerica
+53
-11
make/sun/javazic/tzdata/zone.tab
make/sun/javazic/tzdata/zone.tab
+1
-0
src/share/classes/java/awt/font/NumericShaper.java
src/share/classes/java/awt/font/NumericShaper.java
+849
-451
src/share/classes/javax/swing/JEditorPane.java
src/share/classes/javax/swing/JEditorPane.java
+3
-3
src/share/classes/javax/swing/JList.java
src/share/classes/javax/swing/JList.java
+2
-2
src/share/classes/javax/swing/JTable.java
src/share/classes/javax/swing/JTable.java
+12
-8
src/share/classes/javax/swing/JTextField.java
src/share/classes/javax/swing/JTextField.java
+1
-1
src/share/classes/javax/swing/JTree.java
src/share/classes/javax/swing/JTree.java
+2
-2
src/share/classes/javax/swing/SwingUtilities.java
src/share/classes/javax/swing/SwingUtilities.java
+60
-0
src/share/classes/javax/swing/filechooser/FileSystemView.java
...share/classes/javax/swing/filechooser/FileSystemView.java
+98
-68
src/share/classes/javax/swing/plaf/LayerUI.java
src/share/classes/javax/swing/plaf/LayerUI.java
+402
-10
src/share/classes/javax/swing/plaf/basic/BasicDirectoryModel.java
...e/classes/javax/swing/plaf/basic/BasicDirectoryModel.java
+1
-1
src/share/classes/javax/swing/plaf/metal/OceanTheme.java
src/share/classes/javax/swing/plaf/metal/OceanTheme.java
+2
-1
src/share/classes/javax/swing/plaf/synth/SynthTableUI.java
src/share/classes/javax/swing/plaf/synth/SynthTableUI.java
+1
-1
src/share/classes/javax/swing/table/DefaultTableCellRenderer.java
...e/classes/javax/swing/table/DefaultTableCellRenderer.java
+2
-1
src/share/classes/javax/swing/text/JTextComponent.java
src/share/classes/javax/swing/text/JTextComponent.java
+2
-2
src/share/classes/sun/awt/shell/ShellFolder.java
src/share/classes/sun/awt/shell/ShellFolder.java
+5
-16
src/share/classes/sun/swing/SwingLazyValue.java
src/share/classes/sun/swing/SwingLazyValue.java
+15
-1
src/share/classes/sun/swing/SwingUtilities2.java
src/share/classes/sun/swing/SwingUtilities2.java
+0
-18
src/share/classes/sun/util/resources/TimeZoneNames.java
src/share/classes/sun/util/resources/TimeZoneNames.java
+6
-3
src/share/classes/sun/util/resources/TimeZoneNames_de.java
src/share/classes/sun/util/resources/TimeZoneNames_de.java
+4
-3
src/share/classes/sun/util/resources/TimeZoneNames_es.java
src/share/classes/sun/util/resources/TimeZoneNames_es.java
+5
-3
src/share/classes/sun/util/resources/TimeZoneNames_fr.java
src/share/classes/sun/util/resources/TimeZoneNames_fr.java
+4
-3
src/share/classes/sun/util/resources/TimeZoneNames_it.java
src/share/classes/sun/util/resources/TimeZoneNames_it.java
+4
-3
src/share/classes/sun/util/resources/TimeZoneNames_ja.java
src/share/classes/sun/util/resources/TimeZoneNames_ja.java
+4
-3
src/share/classes/sun/util/resources/TimeZoneNames_ko.java
src/share/classes/sun/util/resources/TimeZoneNames_ko.java
+4
-3
src/share/classes/sun/util/resources/TimeZoneNames_sv.java
src/share/classes/sun/util/resources/TimeZoneNames_sv.java
+4
-3
src/share/classes/sun/util/resources/TimeZoneNames_zh_CN.java
...share/classes/sun/util/resources/TimeZoneNames_zh_CN.java
+4
-3
src/share/classes/sun/util/resources/TimeZoneNames_zh_TW.java
...share/classes/sun/util/resources/TimeZoneNames_zh_TW.java
+4
-3
src/solaris/native/sun/awt/gtk2_interface.c
src/solaris/native/sun/awt/gtk2_interface.c
+1
-1
src/windows/classes/sun/awt/shell/Win32ShellFolder2.java
src/windows/classes/sun/awt/shell/Win32ShellFolder2.java
+27
-24
src/windows/classes/sun/awt/shell/Win32ShellFolderManager2.java
...ndows/classes/sun/awt/shell/Win32ShellFolderManager2.java
+7
-4
test/java/awt/font/NumericShaper/EqualsTest.java
test/java/awt/font/NumericShaper/EqualsTest.java
+65
-0
test/java/awt/font/NumericShaper/MTTest.java
test/java/awt/font/NumericShaper/MTTest.java
+134
-0
test/java/awt/font/NumericShaper/ShapingTest.java
test/java/awt/font/NumericShaper/ShapingTest.java
+105
-0
test/javax/swing/JFileChooser/6550546/bug6550546.java
test/javax/swing/JFileChooser/6550546/bug6550546.java
+57
-0
test/javax/swing/JFileChooser/6741890/bug6741890.java
test/javax/swing/JFileChooser/6741890/bug6741890.java
+107
-0
test/javax/swing/JFileChooser/6868611/bug6868611.java
test/javax/swing/JFileChooser/6868611/bug6868611.java
+93
-0
test/javax/swing/UIDefaults/6795356/SwingLazyValueTest.java
test/javax/swing/UIDefaults/6795356/SwingLazyValueTest.java
+44
-0
test/javax/swing/UIDefaults/6795356/TableTest.java
test/javax/swing/UIDefaults/6795356/TableTest.java
+52
-0
test/javax/swing/UIDefaults/6795356/bug6795356.java
test/javax/swing/UIDefaults/6795356/bug6795356.java
+100
-0
未找到文件。
make/sun/javazic/tzdata/VERSION
浏览文件 @
bf4e9501
...
...
@@ -21,4 +21,4 @@
# CA 95054 USA or visit www.sun.com if you need additional information or
# have any questions.
#
tzdata2009
l
tzdata2009
r
make/sun/javazic/tzdata/antarctica
浏览文件 @
bf4e9501
...
...
@@ -102,15 +102,38 @@ Rule ChileAQ 2000 max - Mar Sun>=9 3:00u 0 -
# Davis, Vestfold Hills, -6835+07759, since 1957-01-13
# (except 1964-11 - 1969-02)
# Mawson, Holme Bay, -6736+06253, since 1954-02-13
# From Steffen Thorsen (2009-03-11):
# Three Australian stations in Antarctica have changed their time zone:
# Casey moved from UTC+8 to UTC+11
# Davis moved from UTC+7 to UTC+5
# Mawson moved from UTC+6 to UTC+5
# The changes occurred on 2009-10-18 at 02:00 (local times).
#
# Government source: (Australian Antarctic Division)
# <a href="http://www.aad.gov.au/default.asp?casid=37079">
# http://www.aad.gov.au/default.asp?casid=37079
# </a>
#
# We have more background information here:
# <a href="http://www.timeanddate.com/news/time/antarctica-new-times.html">
# http://www.timeanddate.com/news/time/antarctica-new-times.html
# </a>
# Zone NAME GMTOFF RULES FORMAT [UNTIL]
Zone Antarctica/Casey 0 - zzz 1969
8:00 - WST # Western (Aus) Standard Time
8:00 - WST 2009 Oct 18 2:00
# Western (Aus) Standard Time
11:00 - CAST # Casey Time
Zone Antarctica/Davis 0 - zzz 1957 Jan 13
7:00 - DAVT 1964 Nov # Davis Time
0 - zzz 1969 Feb
7:00 - DAVT
7:00 - DAVT 2009 Oct 18 2:0
5:00 - DAVT
Zone Antarctica/Mawson 0 - zzz 1954 Feb 13
6:00 - MAWT # Mawson Time
6:00 - MAWT 2009 Oct 18 2:00
# Mawson Time
5:00 - MAWT
# References:
# <a href="http://www.antdiv.gov.au/aad/exop/sfo/casey/casey_aws.html">
# Casey Weather (1998-02-26)
...
...
make/sun/javazic/tzdata/asia
浏览文件 @
bf4e9501
...
...
@@ -21,7 +21,6 @@
# CA 95054 USA or visit www.sun.com if you need additional information or
# have any questions.
#
# <pre>
# This file is in the public domain, so clarified as of
# 2009-05-17 by Arthur David Olson.
...
...
@@ -194,11 +193,30 @@ Zone Asia/Bahrain 3:22:20 - LMT 1920 # Al Manamah
#
# No DST end date has been announced yet.
# From Arthur David Olson (2009-07-11):
# Arbitrarily end DST at the end of 2009 so that a POSIX-sytle time zone string
# can appear in the Dhaka binary file and for the benefit of old glibc
# reimplementations of the time zone software that mishandle permanent DST.
# A change will be required once the end date is known.
# From Alexander Krivenyshev (2009-09-25):
# Bangladesh won't go back to Standard Time from October 1, 2009,
# instead it will continue DST measure till the cabinet makes a fresh decision.
#
# Following report by same newspaper-"The Daily Star Friday":
# "DST change awaits cabinet decision-Clock won't go back by 1-hr from Oct 1"
# <a href="http://www.thedailystar.net/newDesign/news-details.php?nid=107021">
# http://www.thedailystar.net/newDesign/news-details.php?nid=107021
# </a>
# or
# <a href="http://www.worldtimezone.com/dst_news/dst_news_bangladesh04.html">
# http://www.worldtimezone.com/dst_news/dst_news_bangladesh04.html
# </a>
# From Steffen Thorsen (2009-10-13):
# IANS (Indo-Asian News Service) now reports:
# Bangladesh has decided that the clock advanced by an hour to make
# maximum use of daylight hours as an energy saving measure would
# "continue for an indefinite period."
#
# One of many places where it is published:
# <a href="http://www.thaindian.com/newsportal/business/bangladesh-to-continue-indefinitely-with-advanced-time_100259987.html">
# http://www.thaindian.com/newsportal/business/bangladesh-to-continue-indefinitely-with-advanced-time_100259987.html
# </a>
# Zone NAME GMTOFF RULES FORMAT [UNTIL]
Zone Asia/Dhaka 6:01:40 - LMT 1890
...
...
@@ -208,8 +226,7 @@ Zone Asia/Dhaka 6:01:40 - LMT 1890
6:30 - BURT 1951 Sep 30
6:00 - DACT 1971 Mar 26 # Dacca Time
6:00 - BDT 2009 Jun 19 23:00 # Bangladesh Time
6:00 1:00 BDST 2010
6:00 - BDT
6:00 1:00 BDST
# Bhutan
# Zone NAME GMTOFF RULES FORMAT [UNTIL]
...
...
@@ -373,14 +390,84 @@ Zone Asia/Kashgar 5:03:56 - LMT 1928 # or Kashi or Kaxgar
5:00 - KAST 1980 May
8:00 PRC C%sT
# From Lee Yiu Chung (2009-10-24):
# I found there are some mistakes for the historial DST rule for Hong
# Kong. Accoring to the DST record from Hong Kong Observatory (actually,
# it is not [an] observatory, but the official meteorological agency of HK,
# and also serves as the official timing agency), there are some missing
# and incorrect rules. Although the exact switch over time is missing, I
# think 3:30 is correct. The official DST record for Hong Kong can be
# obtained from
# <a href="http://www.hko.gov.hk/gts/time/Summertime.htm">
# http://www.hko.gov.hk/gts/time/Summertime.htm
# </a>.
# From Arthur David Olson (2009-10-28):
# Here are the dates given at
# <a href="http://www.hko.gov.hk/gts/time/Summertime.htm">
# http://www.hko.gov.hk/gts/time/Summertime.htm
# </a>
# as of 2009-10-28:
# Year Period
# 1941 1 Apr to 30 Sep
# 1942 Whole year
# 1943 Whole year
# 1944 Whole year
# 1945 Whole year
# 1946 20 Apr to 1 Dec
# 1947 13 Apr to 30 Dec
# 1948 2 May to 31 Oct
# 1949 3 Apr to 30 Oct
# 1950 2 Apr to 29 Oct
# 1951 1 Apr to 28 Oct
# 1952 6 Apr to 25 Oct
# 1953 5 Apr to 1 Nov
# 1954 21 Mar to 31 Oct
# 1955 20 Mar to 6 Nov
# 1956 18 Mar to 4 Nov
# 1957 24 Mar to 3 Nov
# 1958 23 Mar to 2 Nov
# 1959 22 Mar to 1 Nov
# 1960 20 Mar to 6 Nov
# 1961 19 Mar to 5 Nov
# 1962 18 Mar to 4 Nov
# 1963 24 Mar to 3 Nov
# 1964 22 Mar to 1 Nov
# 1965 18 Apr to 17 Oct
# 1966 17 Apr to 16 Oct
# 1967 16 Apr to 22 Oct
# 1968 21 Apr to 20 Oct
# 1969 20 Apr to 19 Oct
# 1970 19 Apr to 18 Oct
# 1971 18 Apr to 17 Oct
# 1972 16 Apr to 22 Oct
# 1973 22 Apr to 21 Oct
# 1973/74 30 Dec 73 to 20 Oct 74
# 1975 20 Apr to 19 Oct
# 1976 18 Apr to 17 Oct
# 1977 Nil
# 1978 Nil
# 1979 13 May to 21 Oct
# 1980 to Now Nil
# The page does not give start or end times of day.
# The page does not give a start date for 1942.
# The page does not givw an end date for 1945.
# The Japanese occupation of Hong Kong began on 1941-12-25.
# The Japanese surrender of Hong Kong was signed 1945-09-15.
# For lack of anything better, use start of those days as the transition times.
# Hong Kong (Xianggang)
# Rule NAME FROM TO TYPE IN ON AT SAVE LETTER/S
Rule HK 1941 only - Apr 1 3:30 1:00 S
Rule HK 1941 only - Sep 30 3:30 0 -
Rule HK 1946 only - Apr 20 3:30 1:00 S
Rule HK 1946 only - Dec 1 3:30 0 -
Rule HK 1947 only - Apr 13 3:30 1:00 S
Rule HK 1947 only - Dec 30 3:30 0 -
Rule HK 1948 only - May 2 3:30 1:00 S
Rule HK 1948 1952 - Oct lastSun 3:30 0 -
Rule HK 1948 1951 - Oct lastSun 3:30 0 -
Rule HK 1952 only - Oct 25 3:30 0 -
Rule HK 1949 1953 - Apr Sun>=1 3:30 1:00 S
Rule HK 1953 only - Nov 1 3:30 0 -
Rule HK 1954 1964 - Mar Sun>=18 3:30 1:00 S
...
...
@@ -388,13 +475,15 @@ Rule HK 1954 only - Oct 31 3:30 0 -
Rule HK 1955 1964 - Nov Sun>=1 3:30 0 -
Rule HK 1965 1977 - Apr Sun>=16 3:30 1:00 S
Rule HK 1965 1977 - Oct Sun>=16 3:30 0 -
Rule HK 1979 1980 - May Sun>=8 3:30 1:00 S
Rule HK 1979 1980 - Oct Sun>=16 3:30 0 -
Rule HK 1973 only - Dec 30 3:30 1:00 S
Rule HK 1979 only - May Sun>=8 3:30 1:00 S
Rule HK 1979 only - Oct Sun>=16 3:30 0 -
# Zone NAME GMTOFF RULES FORMAT [UNTIL]
Zone Asia/Hong_Kong 7:36:36 - LMT 1904 Oct 30
8:00 HK HK%sT 1941 Dec 25
9:00 - JST 1945 Sep 15
8:00 HK HK%sT
###############################################################################
# Taiwan
...
...
@@ -1696,16 +1785,66 @@ Zone Asia/Muscat 3:54:20 - LMT 1920
# advance clocks in the country by one hour from April 15 to
# conserve energy"
# From Arthur David Olson (2009-04-10):
# Assume for now that Pakistan will end DST in 2009 as it did in 2008.
# From Steffen Thorsen (2009-09-17):
# "The News International," Pakistan reports that: "The Federal
# Government has decided to restore the previous time by moving the
# clocks backward by one hour from October 1. A formal announcement to
# this effect will be made after the Prime Minister grants approval in
# this regard."
# <a href="http://www.thenews.com.pk/updates.asp?id=87168">
# http://www.thenews.com.pk/updates.asp?id=87168
# </a>
# From Alexander Krivenyshev (2009-09-28):
# According to Associated Press Of Pakistan, it is confirmed that
# Pakistan clocks across the country would be turned back by an hour from October
# 1, 2009.
#
# "Clocks to go back one hour from 1 Oct"
# <a href="http://www.app.com.pk/en_/index.php?option=com_content&task=view&id=86715&Itemid=2">
# http://www.app.com.pk/en_/index.php?option=com_content&task=view&id=86715&Itemid=2
# </a>
# or
# <a href="http://www.worldtimezone.com/dst_news/dst_news_pakistan07.htm">
# http://www.worldtimezone.com/dst_news/dst_news_pakistan07.htm
# </a>
# From Steffen Thorsen (2009-09-29):
# Alexander Krivenyshev wrote:
# > According to Associated Press Of Pakistan, it is confirmed that
# > Pakistan clocks across the country would be turned back by an hour from October
# > 1, 2009.
#
# Now they seem to have changed their mind, November 1 is the new date:
# <a href="http://www.thenews.com.pk/top_story_detail.asp?Id=24742">
# http://www.thenews.com.pk/top_story_detail.asp?Id=24742
# </a>
# "The country's clocks will be reversed by one hour on November 1.
# Officials of Federal Ministry for Interior told this to Geo News on
# Monday."
#
# And more importantly, it seems that these dates will be kept every year:
# "It has now been decided that clocks will be wound forward by one hour
# on April 15 and reversed by an hour on November 1 every year without
# obtaining prior approval, the officials added."
#
# We have confirmed this year's end date with both with the Ministry of
# Water and Power and the Pakistan Electric Power Company:
# <a href="http://www.timeanddate.com/news/time/pakistan-ends-dst09.html">
# http://www.timeanddate.com/news/time/pakistan-ends-dst09.html
# </a>
# From Christoph Goehre (2009-10-01):
# [T]he German Consulate General in Karachi reported me today that Pakistan
# will go back to standard time on 1st of November.
# Rule NAME FROM TO TYPE IN ON AT SAVE LETTER/S
Rule Pakistan 2002 only - Apr Sun>=2 0:01 1:00 S
Rule Pakistan 2002 only - Oct Sun>=2 0:01 0 -
Rule Pakistan 2008 only - Jun 1 0:00 1:00 S
Rule Pakistan 2008 only - Nov 1 0:00 0 -
Rule Pakistan 2009
only
- Apr 15 0:00 1:00 S
Rule Pakistan 2009
only
- Nov 1 0:00 0 -
Rule Pakistan 2009
max
- Apr 15 0:00 1:00 S
Rule Pakistan 2009
max
- Nov 1 0:00 0 -
# Zone NAME GMTOFF RULES FORMAT [UNTIL]
Zone Asia/Karachi 4:28:12 - LMT 1907
5:30 - IST 1942 Sep
...
...
@@ -1858,6 +1997,42 @@ Zone Asia/Karachi 4:28:12 - LMT 1907
# http://www.worldtimezone.com/dst_news/dst_news_westbank01.html
# </a>
# From Steffen Thorsen (2009-08-31):
# Palestine's Council of Ministers announced that they will revert back to
# winter time on Friday, 2009-09-04.
#
# One news source:
# <a href="http://www.safa.ps/ara/?action=showdetail&seid=4158">
# http://www.safa.ps/ara/?action=showdetail&seid=4158
# </a>
# (Palestinian press agency, Arabic),
# Google translate: "Decided that the Palestinian government in Ramallah
# headed by Salam Fayyad, the start of work in time for the winter of
# 2009, starting on Friday approved the fourth delay Sept. clock sixty
# minutes per hour as of Friday morning."
#
# We are not sure if Gaza will do the same, last year they had a different
# end date, we will keep this page updated:
# <a href="http://www.timeanddate.com/news/time/westbank-gaza-dst-2009.html">
# http://www.timeanddate.com/news/time/westbank-gaza-dst-2009.html
# </a>
# From Alexander Krivenyshev (2009-09-02):
# Seems that Gaza Strip will go back to Winter Time same date as West Bank.
#
# According to Palestinian Ministry Of Interior, West Bank and Gaza Strip plan
# to change time back to Standard time on September 4, 2009.
#
# "Winter time unite the West Bank and Gaza"
# (from Palestinian National Authority):
# <a href="http://www.moi.gov.ps/en/?page=633167343250594025&nid=11505
# http://www.moi.gov.ps/en/?page=633167343250594025&nid=11505
# </a>
# or
# <a href="http://www.worldtimezone.com/dst_news/dst_news_gazastrip02.html>
# http://www.worldtimezone.com/dst_news/dst_news_gazastrip02.html
# </a>
# The rules for Egypt are stolen from the `africa' file.
# Rule NAME FROM TO TYPE IN ON AT SAVE LETTER/S
Rule EgyptAsia 1957 only - May 10 0:00 1:00 S
...
...
@@ -1876,7 +2051,7 @@ Rule Palestine 2006 only - Sep 22 0:00 0 -
Rule Palestine 2007 only - Sep Thu>=8 2:00 0 -
Rule Palestine 2008 only - Aug lastFri 2:00 0 -
Rule Palestine 2009 max - Mar lastFri 0:00 1:00 S
Rule Palestine 2009 max - Sep
lastMon
2:00 0 -
Rule Palestine 2009 max - Sep
Fri>=1
2:00 0 -
# Zone NAME GMTOFF RULES FORMAT [UNTIL]
Zone Asia/Gaza 2:17:52 - LMT 1900 Oct
...
...
@@ -2154,9 +2329,23 @@ Rule Syria 2007 only - Nov Fri>=1 0:00 0 -
# http://www.timeanddate.com/news/time/syria-dst-starts-march-27-2009.html
# </a>
# From Steffen Thorsen (2009-10-27):
# The Syrian Arab News Network on 2009-09-29 reported that Syria will
# revert back to winter (standard) time on midnight between Thursday
# 2009-10-29 and Friday 2009-10-30:
# <a href="http://www.sana.sy/ara/2/2009/09/29/247012.htm">
# http://www.sana.sy/ara/2/2009/09/29/247012.htm (Arabic)
# </a>
# From Arthur David Olson (2009-10-28):
# We'll see if future DST switching times turn out to be end of the last
# Thursday of the month or the start of the last Friday of the month or
# something else. For now, use the start of the last Friday.
Rule Syria 2008 only - Apr Fri>=1 0:00 1:00 S
Rule Syria 2008
max
- Nov 1 0:00 0 -
Rule Syria 2008
only
- Nov 1 0:00 0 -
Rule Syria 2009 max - Mar lastFri 0:00 1:00 S
Rule Syria 2009 max - Oct lastFri 0:00 0 -
# Zone NAME GMTOFF RULES FORMAT [UNTIL]
Zone Asia/Damascus 2:25:12 - LMT 1920 # Dimashq
...
...
make/sun/javazic/tzdata/australasia
浏览文件 @
bf4e9501
...
...
@@ -465,10 +465,56 @@ Zone Pacific/Pago_Pago 12:37:12 - LMT 1879 Jul 5
# http://www.worldtimezone.com/dst_news/dst_news_samoa01.html
# </a>
# From Steffen Thorsen (2009-08-27):
# Samoa's parliament passed the Daylight Saving Bill 2009, and will start
# daylight saving time on the first Sunday of October 2009 and end on the
# last Sunday of March 2010. We hope that the full text will be published
# soon, but we believe that the bill is only valid for 2009-2010. Samoa's
# Daylight Saving Act 2009 will be enforced as soon as the Head of State
# executes a proclamation publicizing this Act.
#
# Some background information here, which will be updated once we have
# more details:
# <a href="http://www.timeanddate.com/news/time/samoa-dst-plan-2009.html">
# http://www.timeanddate.com/news/time/samoa-dst-plan-2009.html
# </a>
# From Alexander Krivenyshev (2009-10-03):
# First, my deepest condolences to people of Samoa islands and all families and
# loved ones around the world who lost their lives in the earthquake and tsunami.
#
# Considering the recent devastation on Samoa by earthquake and tsunami and that
# many government offices/ ministers are closed- not sure if "Daylight Saving
# Bill 2009" will be implemented in next few days- on October 4, 2009.
#
# Here is reply from Consulate-General of Samoa in New Zealand
# ---------------------------
# Consul General
# consulgeneral@samoaconsulate.org.nz
#
# Talofa Alexander,
#
# Thank you for your sympathy for our country but at this time we have not
# been informed about the Daylight Savings Time Change. Most Ministries in
# Apia are closed or relocating due to weather concerns.
#
# When we do find out if they are still proceeding with the time change we
# will advise you soonest.
#
# Kind Regards,
# Lana
# for: Consul General
# From Steffen Thorsen (2009-10-05):
# We have called a hotel in Samoa and asked about local time there - they
# are still on standard time.
Zone Pacific/Apia 12:33:04 - LMT 1879 Jul 5
-11:26:56 - LMT 1911
-11:30 - SAMT 1950 # Samoa Time
-11:00 - WST # Samoa Time
-11:00 - WST 2009 Oct 4
-11:00 1:00 WSDT 2010 Mar 28
-11:00 - WST
# Solomon Is
# excludes Bougainville, for which see Papua New Guinea
...
...
make/sun/javazic/tzdata/europe
浏览文件 @
bf4e9501
...
...
@@ -2094,9 +2094,43 @@ Zone Asia/Novosibirsk 5:31:40 - LMT 1919 Dec 14 6:00
6:00 Russia NOV%sT 1992 Jan 19 2:00s
7:00 Russia NOV%sT 1993 May 23 # say Shanks & P.
6:00 Russia NOV%sT
# From Alexander Krivenyshev (2009-10-13):
# Kemerovo oblast' (Kemerovo region) in Russia will change current time zone on
# March 28, 2010:
# from current Russia Zone 6 - Krasnoyarsk Time Zone (KRA) UTC +0700
# to Russia Zone 5 - Novosibirsk Time Zone (NOV) UTC +0600
#
# This is according to Government of Russia decree # 740, on September
# 14, 2009 "Application in the territory of the Kemerovo region the Fifth
# time zone." ("Russia Zone 5" or old "USSR Zone 5" is GMT +0600)
#
# Russian Government web site (Russian language)
# <a href="http://www.government.ru/content/governmentactivity/rfgovernmentdecisions/archiv">
# http://www.government.ru/content/governmentactivity/rfgovernmentdecisions/archive/2009/09/14/991633.htm
# </a>
# or Russian-English translation by WorldTimeZone.com with reference
# map to local region and new Russia Time Zone map after March 28, 2010
# <a href="http://www.worldtimezone.com/dst_news/dst_news_russia03.html">
# http://www.worldtimezone.com/dst_news/dst_news_russia03.html
# </a>
#
# Thus, when Russia will switch to DST on the night of March 28, 2010
# Kemerovo region (Kemerovo oblast') will not change the clock.
#
# As a result, Kemerovo oblast' will be in the same time zone as
# Novosibirsk, Omsk, Tomsk, Barnaul and Altai Republic.
Zone Asia/Novokuznetsk 5:48:48 - NMT 1920 Jan 6
6:00 - KRAT 1930 Jun 21 # Krasnoyarsk Time
7:00 Russia KRA%sT 1991 Mar 31 2:00s
6:00 Russia KRA%sT 1992 Jan 19 2:00s
7:00 Russia KRA%sT 2010 Mar 28 2:00s
6:00 Russia NOV%sT # Novosibirsk/Novokuznetsk Time
#
# From Oscar van Vlijmen (2001-08-25): [This region consists of]
# K
emerovskaya oblast', K
rasnoyarskij kraj,
# Krasnoyarskij kraj,
# Tajmyrskij (Dolgano-Nenetskij) avtonomnyj okrug,
# Respublika Tuva, Respublika Khakasiya, Evenkijskij avtonomnyj okrug.
Zone Asia/Krasnoyarsk 6:11:20 - LMT 1920 Jan 6
...
...
make/sun/javazic/tzdata/southamerica
浏览文件 @
bf4e9501
...
...
@@ -237,9 +237,23 @@ Rule Arg 2000 only - Mar 3 0:00 0 -
# http://www.jujuy.gov.ar/index2/partes_prensa/18_10_08/235-181008.doc
# </a>
# From fullinet (2009-10-18):
# As announced in
# <a hef="http://www.argentina.gob.ar/argentina/portal/paginas.dhtml?pagina=356">
# http://www.argentina.gob.ar/argentina/portal/paginas.dhtml?pagina=356
# </a>
# (an official .gob.ar) under title: "Sin Cambio de Hora" (english: "No hour change")
#
# "Por el momento, el Gobierno Nacional resolvio no modificar la hora
# oficial, decision que estaba en estudio para su implementacion el
# domingo 18 de octubre. Desde el Ministerio de Planificacion se anuncio
# que la Argentina hoy, en estas condiciones meteorologicas, no necesita
# la modificacion del huso horario, ya que 2009 nos encuentra con
# crecimiento en la produccion y distribucion energetica."
Rule Arg 2007 only - Dec 30 0:00 1:00 S
Rule Arg 2008
max
- Mar Sun>=15 0:00 0 -
Rule Arg 2008
max
- Oct Sun>=15 0:00 1:00 S
Rule Arg 2008
2009
- Mar Sun>=15 0:00 0 -
Rule Arg 2008
only
- Oct Sun>=15 0:00 1:00 S
# From Mariano Absatz (2004-05-21):
# Today it was officially published that the Province of Mendoza is changing
...
...
@@ -411,15 +425,40 @@ Rule Arg 2008 max - Oct Sun>=15 0:00 1:00 S
# during 2009, this timezone change will run from 00:00 the third Sunday
# in March until 24:00 of the second Saturday in October.
# From Arthur David Olson (2009-03-16):
# The unofficial claim at
# <a href="http://www.timeanddate.com/news/time/san-luis-new-time-zone.html">
# http://www.timeanddate.com/news/time/san-luis-new-time-zone.html
# From Mariano Absatz (2009-10-16):
# ...the Province of San Luis is a case in itself.
#
# The Law at
# <a href="http://www.diputadossanluis.gov.ar/diputadosasp/paginas/verNorma.asp?NormaID=276>"
# http://www.diputadossanluis.gov.ar/diputadosasp/paginas/verNorma.asp?NormaID=276
# </a>
# is that "The province will most likely follow the next daylight saving schedule,
# which is planned for the second Sunday in October."
# is ambiguous because establishes a calendar from the 2nd Sunday in
# October at 0:00 thru the 2nd Saturday in March at 24:00 and the
# complement of that starting on the 2nd Sunday of March at 0:00 and
# ending on the 2nd Saturday of March at 24:00.
#
# This clearly breaks every time the 1st of March or October is a Sunday.
#
# IMHO, the "spirit of the Law" is to make the changes at 0:00 on the 2nd
# Sunday of October and March.
#
# The problem is that the changes in the rest of the Provinces that did
# change in 2007/2008, were made according to the Federal Law and Decrees
# that did so on the 3rd Sunday of October and March.
#
# In fact, San Luis actually switched from UTC-4 to UTC-3 last Sunday
# (October 11th) at 0:00.
#
# So I guess a new set of rules, besides "Arg", must be made and the last
# America/Argentina/San_Luis entries should change to use these...
#
# I'm enclosing a patch that does what I say... regretfully, the San Luis
# timezone must be called "WART/WARST" even when most of the time (like,
# right now) WARST == ART... that is, since last Sunday, all the country
# is using UTC-3, but in my patch, San Luis calls it "WARST" and the rest
# of the country calls it "ART".
# ...
# Zone NAME GMTOFF RULES FORMAT [UNTIL]
#
# Buenos Aires (BA), Capital Federal (CF),
...
...
@@ -552,6 +591,10 @@ Zone America/Argentina/Mendoza -4:35:16 - LMT 1894 Oct 31
-3:00 - ART
#
# San Luis (SL)
Rule SanLuis 2008 max - Mar Sun>=8 0:00 0 -
Rule SanLuis 2007 max - Oct Sun>=8 0:00 1:00 S
Zone America/Argentina/San_Luis -4:25:24 - LMT 1894 Oct 31
-4:16:48 - CMT 1920 May
-4:00 - ART 1930 Dec
...
...
@@ -566,8 +609,7 @@ Zone America/Argentina/San_Luis -4:25:24 - LMT 1894 Oct 31
-3:00 - ART 2004 May 31
-4:00 - WART 2004 Jul 25
-3:00 Arg AR%sT 2008 Jan 21
-3:00 - ART 2009 Mar 15
-4:00 Arg WAR%sT
-4:00 SanLuis WAR%sT
#
# Santa Cruz (SC)
Zone America/Argentina/Rio_Gallegos -4:36:52 - LMT 1894 Oct 31
...
...
make/sun/javazic/tzdata/zone.tab
浏览文件 @
bf4e9501
...
...
@@ -352,6 +352,7 @@ RU +5312+05009 Europe/Samara Moscow+01 - Samara, Udmurtia
RU +5651+06036 Asia/Yekaterinburg Moscow+02 - Urals
RU +5500+07324 Asia/Omsk Moscow+03 - west Siberia
RU +5502+08255 Asia/Novosibirsk Moscow+03 - Novosibirsk
RU +5345+08707 Asia/Novokuznetsk Moscow+03 - Novokuznetsk
RU +5601+09250 Asia/Krasnoyarsk Moscow+04 - Yenisei River
RU +5216+10420 Asia/Irkutsk Moscow+05 - Lake Baikal
RU +6200+12940 Asia/Yakutsk Moscow+06 - Lena River
...
...
src/share/classes/java/awt/font/NumericShaper.java
浏览文件 @
bf4e9501
此差异已折叠。
点击以展开。
src/share/classes/javax/swing/JEditorPane.java
浏览文件 @
bf4e9501
...
...
@@ -1330,7 +1330,7 @@ public class JEditorPane extends JTextComponent {
*/
public
Dimension
getPreferredSize
()
{
Dimension
d
=
super
.
getPreferredSize
();
JViewport
port
=
SwingUtilities
2
.
ge
tViewport
(
this
);
JViewport
port
=
SwingUtilities
.
getParen
tViewport
(
this
);
if
(
port
!=
null
)
{
TextUI
ui
=
getUI
();
int
prefWidth
=
d
.
width
;
...
...
@@ -1452,7 +1452,7 @@ public class JEditorPane extends JTextComponent {
* match its own, false otherwise
*/
public
boolean
getScrollableTracksViewportWidth
()
{
JViewport
port
=
SwingUtilities
2
.
ge
tViewport
(
this
);
JViewport
port
=
SwingUtilities
.
getParen
tViewport
(
this
);
if
(
port
!=
null
)
{
TextUI
ui
=
getUI
();
int
w
=
port
.
getWidth
();
...
...
@@ -1474,7 +1474,7 @@ public class JEditorPane extends JTextComponent {
* false otherwise
*/
public
boolean
getScrollableTracksViewportHeight
()
{
JViewport
port
=
SwingUtilities
2
.
ge
tViewport
(
this
);
JViewport
port
=
SwingUtilities
.
getParen
tViewport
(
this
);
if
(
port
!=
null
)
{
TextUI
ui
=
getUI
();
int
h
=
port
.
getHeight
();
...
...
src/share/classes/javax/swing/JList.java
浏览文件 @
bf4e9501
...
...
@@ -2722,7 +2722,7 @@ public class JList extends JComponent implements Scrollable, Accessible
getVisibleRowCount
()
<=
0
)
{
return
true
;
}
JViewport
port
=
SwingUtilities
2
.
ge
tViewport
(
this
);
JViewport
port
=
SwingUtilities
.
getParen
tViewport
(
this
);
if
(
port
!=
null
)
{
return
port
.
getWidth
()
>
getPreferredSize
().
width
;
}
...
...
@@ -2748,7 +2748,7 @@ public class JList extends JComponent implements Scrollable, Accessible
getVisibleRowCount
()
<=
0
)
{
return
true
;
}
JViewport
port
=
SwingUtilities
2
.
ge
tViewport
(
this
);
JViewport
port
=
SwingUtilities
.
getParen
tViewport
(
this
);
if
(
port
!=
null
)
{
return
port
.
getHeight
()
>
getPreferredSize
().
height
;
}
...
...
src/share/classes/javax/swing/JTable.java
浏览文件 @
bf4e9501
...
...
@@ -57,6 +57,7 @@ import sun.swing.SwingUtilities2;
import
sun.swing.SwingUtilities2.Section
;
import
static
sun
.
swing
.
SwingUtilities2
.
Section
.*;
import
sun.swing.PrintingStatus
;
import
sun.swing.SwingLazyValue
;
/**
* The <code>JTable</code> is used to display and edit regular two-dimensional tables
...
...
@@ -718,7 +719,7 @@ public class JTable extends JComponent implements TableModelListener, Scrollable
* @see #addNotify
*/
protected
void
configureEnclosingScrollPane
()
{
JViewport
port
=
SwingUtilities
2
.
ge
tViewport
(
this
);
JViewport
port
=
SwingUtilities
.
getParen
tViewport
(
this
);
if
(
port
!=
null
)
{
Container
gp
=
port
.
getParent
();
if
(
gp
instanceof
JScrollPane
)
{
...
...
@@ -727,7 +728,8 @@ public class JTable extends JComponent implements TableModelListener, Scrollable
// example, the rowHeaderView of the scrollPane -
// an implementor of fixed columns might do this.
JViewport
viewport
=
scrollPane
.
getViewport
();
if
(
viewport
==
null
||
viewport
.
getView
()
!=
this
)
{
if
(
viewport
==
null
||
SwingUtilities
.
getUnwrappedView
(
viewport
)
!=
this
)
{
return
;
}
scrollPane
.
setColumnHeaderView
(
getTableHeader
());
...
...
@@ -750,7 +752,7 @@ public class JTable extends JComponent implements TableModelListener, Scrollable
* from configureEnclosingScrollPane() and updateUI() in a safe manor.
*/
private
void
configureEnclosingScrollPaneUI
()
{
JViewport
port
=
SwingUtilities
2
.
ge
tViewport
(
this
);
JViewport
port
=
SwingUtilities
.
getParen
tViewport
(
this
);
if
(
port
!=
null
)
{
Container
gp
=
port
.
getParent
();
if
(
gp
instanceof
JScrollPane
)
{
...
...
@@ -759,7 +761,8 @@ public class JTable extends JComponent implements TableModelListener, Scrollable
// example, the rowHeaderView of the scrollPane -
// an implementor of fixed columns might do this.
JViewport
viewport
=
scrollPane
.
getViewport
();
if
(
viewport
==
null
||
viewport
.
getView
()
!=
this
)
{
if
(
viewport
==
null
||
SwingUtilities
.
getUnwrappedView
(
viewport
)
!=
this
)
{
return
;
}
// scrollPane.getViewport().setBackingStoreEnabled(true);
...
...
@@ -819,7 +822,7 @@ public class JTable extends JComponent implements TableModelListener, Scrollable
* @since 1.3
*/
protected
void
unconfigureEnclosingScrollPane
()
{
JViewport
port
=
SwingUtilities
2
.
ge
tViewport
(
this
);
JViewport
port
=
SwingUtilities
.
getParen
tViewport
(
this
);
if
(
port
!=
null
)
{
Container
gp
=
port
.
getParent
();
if
(
gp
instanceof
JScrollPane
)
{
...
...
@@ -828,7 +831,8 @@ public class JTable extends JComponent implements TableModelListener, Scrollable
// example, the rowHeaderView of the scrollPane -
// an implementor of fixed columns might do this.
JViewport
viewport
=
scrollPane
.
getViewport
();
if
(
viewport
==
null
||
viewport
.
getView
()
!=
this
)
{
if
(
viewport
==
null
||
SwingUtilities
.
getUnwrappedView
(
viewport
)
!=
this
)
{
return
;
}
scrollPane
.
setColumnHeaderView
(
null
);
...
...
@@ -5215,7 +5219,7 @@ public class JTable extends JComponent implements TableModelListener, Scrollable
* @see #getFillsViewportHeight
*/
public
boolean
getScrollableTracksViewportHeight
()
{
JViewport
port
=
SwingUtilities
2
.
ge
tViewport
(
this
);
JViewport
port
=
SwingUtilities
.
getParen
tViewport
(
this
);
return
getFillsViewportHeight
()
&&
port
!=
null
&&
port
.
getHeight
()
>
getPreferredSize
().
height
;
...
...
@@ -5316,7 +5320,7 @@ public class JTable extends JComponent implements TableModelListener, Scrollable
}
private
void
setLazyValue
(
Hashtable
h
,
Class
c
,
String
s
)
{
h
.
put
(
c
,
new
UIDefaults
.
Proxy
LazyValue
(
s
));
h
.
put
(
c
,
new
Swing
LazyValue
(
s
));
}
private
void
setLazyRenderer
(
Class
c
,
String
s
)
{
...
...
src/share/classes/javax/swing/JTextField.java
浏览文件 @
bf4e9501
...
...
@@ -292,7 +292,7 @@ public class JTextField extends JTextComponent implements SwingConstants {
*/
@Override
public
boolean
isValidateRoot
()
{
return
SwingUtilities
2
.
ge
tViewport
(
this
)
==
null
;
return
SwingUtilities
.
getParen
tViewport
(
this
)
==
null
;
}
...
...
src/share/classes/javax/swing/JTree.java
浏览文件 @
bf4e9501
...
...
@@ -3498,7 +3498,7 @@ public class JTree extends JComponent implements Scrollable, Accessible
* @see Scrollable#getScrollableTracksViewportWidth
*/
public
boolean
getScrollableTracksViewportWidth
()
{
JViewport
port
=
SwingUtilities
2
.
ge
tViewport
(
this
);
JViewport
port
=
SwingUtilities
.
getParen
tViewport
(
this
);
if
(
port
!=
null
)
{
return
port
.
getWidth
()
>
getPreferredSize
().
width
;
}
...
...
@@ -3515,7 +3515,7 @@ public class JTree extends JComponent implements Scrollable, Accessible
* @see Scrollable#getScrollableTracksViewportHeight
*/
public
boolean
getScrollableTracksViewportHeight
()
{
JViewport
port
=
SwingUtilities
2
.
ge
tViewport
(
this
);
JViewport
port
=
SwingUtilities
.
getParen
tViewport
(
this
);
if
(
port
!=
null
)
{
return
port
.
getHeight
()
>
getPreferredSize
().
height
;
}
...
...
src/share/classes/javax/swing/SwingUtilities.java
浏览文件 @
bf4e9501
...
...
@@ -1969,6 +1969,66 @@ public class SwingUtilities implements SwingConstants
}
/**
* Looks for the first ancestor of the {@code component}
* which is not an instance of {@link JLayer}.
* If this ancestor is an instance of {@code JViewport},
* this {@code JViewport} is returned, otherwise returns {@code null}.
* The following way of obtaining the parent {@code JViewport}
* is not recommended any more:
* <pre>
* JViewport port = null;
* Container parent = component.getParent();
* // not recommended any more
* if(parent instanceof JViewport) {
* port = (JViewport) parent;
* }
* </pre>
* Here is the way to go:
* <pre>
* // the correct way:
* JViewport port = SwingUtilities.getParentViewport(component);
* </pre>
* @param component {@code Component} to get the parent {@code JViewport} of.
* @return the {@code JViewport} instance for the {@code component}
* or {@code null}
* @throws NullPointerException if {@code component} is {@code null}
*
* @since 1.7
*/
public
static
JViewport
getParentViewport
(
Component
component
)
{
do
{
component
=
component
.
getParent
();
if
(
component
instanceof
JViewport
)
{
return
(
JViewport
)
component
;
}
}
while
(
component
instanceof
JLayer
);
return
null
;
}
/**
* Returns the first {@code JViewport}'s descendant
* which is not an instance of {@code JLayer} or {@code null}.
*
* If the {@code viewport}'s view component is not a {@code JLayer},
* this method is equal to {@link JViewport#getView()}
* otherwise {@link JLayer#getView()} will be recursively tested
*
* @return the first {@code JViewport}'s descendant
* which is not an instance of {@code JLayer} or {@code null}.
*
* @throws NullPointerException if {@code viewport} is {@code null}
* @see JViewport#getView()
* @see JLayer
*/
static
Component
getUnwrappedView
(
JViewport
viewport
)
{
Component
view
=
viewport
.
getView
();
while
(
view
instanceof
JLayer
)
{
view
=
((
JLayer
)
view
).
getView
();
}
return
view
;
}
/**
* Retrieves the validate root of a given container.
*
* If the container is contained within a {@code CellRendererPane}, this
...
...
src/share/classes/javax/swing/filechooser/FileSystemView.java
浏览文件 @
bf4e9501
...
...
@@ -33,7 +33,8 @@ import java.io.File;
import
java.io.FileNotFoundException
;
import
java.io.IOException
;
import
java.text.MessageFormat
;
import
java.util.Vector
;
import
java.util.List
;
import
java.util.ArrayList
;
import
java.lang.ref.WeakReference
;
import
java.beans.PropertyChangeListener
;
import
java.beans.PropertyChangeEvent
;
...
...
@@ -173,22 +174,27 @@ public abstract class FileSystemView {
* @since 1.4
*/
public
String
getSystemDisplayName
(
File
f
)
{
String
name
=
null
;
if
(
f
!=
null
)
{
name
=
f
.
getName
();
if
(!
name
.
equals
(
".."
)
&&
!
name
.
equals
(
"."
)
&&
(
useSystemExtensionHiding
||
!
isFileSystem
(
f
)
||
isFileSystemRoot
(
f
)
)
&&
(
(
f
instanceof
ShellFolder
)
||
f
.
exists
()))
{
if
(
f
==
null
)
{
return
null
;
}
String
name
=
f
.
getName
();
if
(!
name
.
equals
(
".."
)
&&
!
name
.
equals
(
"."
)
&&
(
useSystemExtensionHiding
||
!
isFileSystem
(
f
)
||
isFileSystemRoot
(
f
))
&&
(
f
instanceof
ShellFolder
||
f
.
exists
()))
{
try
{
name
=
getShellFolder
(
f
).
getDisplayName
();
if
(
name
==
null
||
name
.
length
()
==
0
)
{
name
=
f
.
getPath
();
// e.g. "/"
}
}
catch
(
FileNotFoundException
e
)
{
return
null
;
}
if
(
name
==
null
||
name
.
length
()
==
0
)
{
name
=
f
.
getPath
();
// e.g. "/"
}
}
return
name
;
}
...
...
@@ -222,17 +228,25 @@ public abstract class FileSystemView {
* @since 1.4
*/
public
Icon
getSystemIcon
(
File
f
)
{
if
(
f
!=
null
)
{
ShellFolder
sf
=
getShellFolder
(
f
);
Image
img
=
sf
.
getIcon
(
false
);
if
(
img
!=
null
)
{
return
new
ImageIcon
(
img
,
sf
.
getFolderType
());
}
else
{
return
UIManager
.
getIcon
(
f
.
isDirectory
()
?
"FileView.directoryIcon"
:
"FileView.fileIcon"
);
}
}
else
{
if
(
f
==
null
)
{
return
null
;
}
ShellFolder
sf
;
try
{
sf
=
getShellFolder
(
f
);
}
catch
(
FileNotFoundException
e
)
{
return
null
;
}
Image
img
=
sf
.
getIcon
(
false
);
if
(
img
!=
null
)
{
return
new
ImageIcon
(
img
,
sf
.
getFolderType
());
}
else
{
return
UIManager
.
getIcon
(
f
.
isDirectory
()
?
"FileView.directoryIcon"
:
"FileView.fileIcon"
);
}
}
/**
...
...
@@ -446,24 +460,28 @@ public abstract class FileSystemView {
* Gets the list of shown (i.e. not hidden) files.
*/
public
File
[]
getFiles
(
File
dir
,
boolean
useFileHiding
)
{
Vector
<
File
>
files
=
new
Vector
<
File
>();
List
<
File
>
files
=
new
ArrayList
<
File
>();
// add all files in dir
File
[]
names
;
if
(!(
dir
instanceof
ShellFolder
))
{
if
(!(
dir
instanceof
ShellFolder
))
{
try
{
dir
=
getShellFolder
(
dir
);
}
catch
(
FileNotFoundException
e
)
{
return
new
File
[
0
];
}
}
names
=
((
ShellFolder
)
dir
).
listFiles
(!
useFileHiding
);
File
f
;
File
[]
names
=
((
ShellFolder
)
dir
).
listFiles
(!
useFileHiding
);
int
nameCount
=
(
names
==
null
)
?
0
:
names
.
length
;
for
(
int
i
=
0
;
i
<
nameCount
;
i
++)
{
if
(
names
==
null
)
{
return
new
File
[
0
];
}
for
(
File
f
:
names
)
{
if
(
Thread
.
currentThread
().
isInterrupted
())
{
break
;
}
f
=
names
[
i
];
if
(!(
f
instanceof
ShellFolder
))
{
if
(
isFileSystemRoot
(
f
))
{
f
=
createFileSystemRoot
(
f
);
...
...
@@ -481,7 +499,7 @@ public abstract class FileSystemView {
}
}
if
(!
useFileHiding
||
!
isHiddenFile
(
f
))
{
files
.
add
Element
(
f
);
files
.
add
(
f
);
}
}
...
...
@@ -497,42 +515,50 @@ public abstract class FileSystemView {
* <code>null</code> if <code>dir</code> is <code>null</code>
*/
public
File
getParentDirectory
(
File
dir
)
{
if
(
dir
!=
null
&&
dir
.
exists
())
{
ShellFolder
sf
=
getShellFolder
(
dir
);
File
psf
=
sf
.
getParentFile
();
if
(
psf
!=
null
)
{
if
(
isFileSystem
(
psf
))
{
File
f
=
psf
;
if
(
f
!=
null
&&
!
f
.
exists
())
{
// This could be a node under "Network Neighborhood".
File
ppsf
=
psf
.
getParentFile
();
if
(
ppsf
==
null
||
!
isFileSystem
(
ppsf
))
{
// We're mostly after the exists() override for windows below.
f
=
createFileSystemRoot
(
f
);
}
}
return
f
;
}
else
{
return
psf
;
if
(
dir
==
null
||
!
dir
.
exists
())
{
return
null
;
}
ShellFolder
sf
;
try
{
sf
=
getShellFolder
(
dir
);
}
catch
(
FileNotFoundException
e
)
{
return
null
;
}
File
psf
=
sf
.
getParentFile
();
if
(
psf
==
null
)
{
return
null
;
}
if
(
isFileSystem
(
psf
))
{
File
f
=
psf
;
if
(!
f
.
exists
())
{
// This could be a node under "Network Neighborhood".
File
ppsf
=
psf
.
getParentFile
();
if
(
ppsf
==
null
||
!
isFileSystem
(
ppsf
))
{
// We're mostly after the exists() override for windows below.
f
=
createFileSystemRoot
(
f
);
}
}
return
f
;
}
else
{
return
psf
;
}
return
null
;
}
ShellFolder
getShellFolder
(
File
f
)
{
if
(!(
f
instanceof
ShellFolder
)
&&
!(
f
instanceof
FileSystemRoot
)
&&
isFileSystemRoot
(
f
))
{
/**
* Throws {@code FileNotFoundException} if file not found or current thread was interrupted
*/
ShellFolder
getShellFolder
(
File
f
)
throws
FileNotFoundException
{
if
(!(
f
instanceof
ShellFolder
)
&&
!(
f
instanceof
FileSystemRoot
)
&&
isFileSystemRoot
(
f
))
{
f
=
createFileSystemRoot
(
f
);
}
try
{
return
ShellFolder
.
getShellFolder
(
f
);
}
catch
(
FileNotFoundException
e
)
{
System
.
err
.
println
(
"FileSystemView.getShellFolder: f="
+
f
);
e
.
printStackTrace
();
return
null
;
}
catch
(
InternalError
e
)
{
System
.
err
.
println
(
"FileSystemView.getShellFolder: f="
+
f
);
e
.
printStackTrace
();
...
...
@@ -596,9 +622,9 @@ class UnixFileSystemView extends FileSystemView {
// Unix - using OpenWindows' default folder name. Can't find one for Motif/CDE.
newFolder
=
createFileObject
(
containingDir
,
newFolderString
);
int
i
=
1
;
while
(
newFolder
.
exists
()
&&
(
i
<
100
)
)
{
while
(
newFolder
.
exists
()
&&
i
<
100
)
{
newFolder
=
createFileObject
(
containingDir
,
MessageFormat
.
format
(
newFolderNextString
,
new
Object
[]
{
new
Integer
(
i
)
}
));
newFolderNextString
,
new
Integer
(
i
)
));
i
++;
}
...
...
@@ -612,7 +638,7 @@ class UnixFileSystemView extends FileSystemView {
}
public
boolean
isFileSystemRoot
(
File
dir
)
{
return
(
dir
!=
null
&&
dir
.
getAbsolutePath
().
equals
(
"/"
)
);
return
dir
!=
null
&&
dir
.
getAbsolutePath
().
equals
(
"/"
);
}
public
boolean
isDrive
(
File
dir
)
{
...
...
@@ -654,7 +680,7 @@ class WindowsFileSystemView extends FileSystemView {
public
File
getChild
(
File
parent
,
String
fileName
)
{
if
(
fileName
.
startsWith
(
"\\"
)
&&
!
(
fileName
.
startsWith
(
"\\\\"
)
)
&&
!
fileName
.
startsWith
(
"\\\\"
)
&&
isFileSystem
(
parent
))
{
//Path is relative to the root of parent's drive
...
...
@@ -677,9 +703,13 @@ class WindowsFileSystemView extends FileSystemView {
* The Windows implementation gets information from the ShellFolder class.
*/
public
String
getSystemTypeDescription
(
File
f
)
{
if
(
f
!=
null
)
{
if
(
f
==
null
)
{
return
null
;
}
try
{
return
getShellFolder
(
f
).
getFolderType
();
}
else
{
}
catch
(
FileNotFoundException
e
)
{
return
null
;
}
}
...
...
@@ -701,9 +731,9 @@ class WindowsFileSystemView extends FileSystemView {
// Using NT's default folder name
File
newFolder
=
createFileObject
(
containingDir
,
newFolderString
);
int
i
=
2
;
while
(
newFolder
.
exists
()
&&
(
i
<
100
)
)
{
while
(
newFolder
.
exists
()
&&
i
<
100
)
{
newFolder
=
createFileObject
(
containingDir
,
MessageFormat
.
format
(
newFolderNextString
,
new
Object
[]
{
new
Integer
(
i
)
}
));
newFolderNextString
,
new
Integer
(
i
)
));
i
++;
}
...
...
@@ -727,7 +757,7 @@ class WindowsFileSystemView extends FileSystemView {
}
});
return
(
path
!=
null
&&
(
path
.
equals
(
"A:\\"
)
||
path
.
equals
(
"B:\\"
)
));
return
path
!=
null
&&
(
path
.
equals
(
"A:\\"
)
||
path
.
equals
(
"B:\\"
));
}
/**
...
...
src/share/classes/javax/swing/plaf/LayerUI.java
浏览文件 @
bf4e9501
...
...
@@ -71,33 +71,410 @@ public class LayerUI<V extends Component>
* Subclasses should override this method and use
* the specified {@code Graphics} object to
* render the content of the component.
* <p/>
* If {@code g} is not an instance of {@code Graphics2D},
* this method is no-op.
*
* @param g the {@code Graphics} context in which to paint;
* @param c the component being painted;
* it can be safely cast to the {@code JLayer<V>}
* it can be safely cast to {@code JLayer<? extends V>}
*
* @see #configureGraphics(Graphics2D, JLayer)
* @see #paintLayer(Graphics2D, JLayer)
*/
@Override
public
void
paint
(
Graphics
g
,
JComponent
c
)
{
c
.
paint
(
g
);
if
(
g
instanceof
Graphics2D
)
{
Graphics2D
g2
=
(
Graphics2D
)
g
.
create
();
JLayer
<?
extends
V
>
l
=
(
JLayer
<?
extends
V
>)
c
;
configureGraphics
(
g2
,
l
);
paintLayer
(
g2
,
l
);
g2
.
dispose
();
}
}
/**
* This method is called by the {@link #paint} method prior to
* {@link #paintLayer} to configure the {@code Graphics2D} object.
* The default implementation is empty.
*
* @param g2 the {@code Graphics2D} object to configure
* @param l the {@code JLayer} being painted
*
* @see #paintLayer(Graphics2D, JLayer)
*/
protected
void
configureGraphics
(
Graphics2D
g2
,
JLayer
<?
extends
V
>
l
)
{
}
/**
* Called by the {@link #paint} method,
* subclasses should override this method
* to perform any custom painting operations.
* <p/>
* The default implementation paints the passed {@code JLayer} as is.
*
* @param g2 the {@code Graphics2D} context in which to paint
* @param l the {@code JLayer} being painted
*
* @see #configureGraphics(Graphics2D, JLayer)
*/
protected
void
paintLayer
(
Graphics2D
g2
,
JLayer
<?
extends
V
>
l
)
{
l
.
paint
(
g2
);
}
/**
* Dispatches {@code AWTEvent}s for {@code JLayer}
* and <b>all it subcomponents</b> to this {@code LayerUI} instance.
* <p>
* To enable the {@code AWTEvent}
of the
particular type,
* you call {@link
javax.swing.
JLayer#setLayerEventMask}
* and <b>all it
s
subcomponents</b> to this {@code LayerUI} instance.
* <p
/
>
* To enable the {@code AWTEvent}
s of a
particular type,
* you call {@link JLayer#setLayerEventMask}
* in {@link #installUI(javax.swing.JComponent)}
* and set the layer event mask to {@code 0}
* in {@link #uninstallUI(javax.swing.JComponent)} after that
* in {@link #uninstallUI(javax.swing.JComponent)} after that.
* By default this method calls the appropriate
* {@code process<event type>Event}
* method for the given class of event.
*
* @param e the event to be dispatched
* @param l the layer this LayerUI is set to
*
* @see JLayer#setLayerEventMask(long)
* @see javax.swing.JLayer#getLayerEventMask()
* @see #installUI(javax.swing.JComponent)
* @see #uninstallUI(javax.swing.JComponent)
* @see #processComponentEvent
* @see #processFocusEvent
* @see #processKeyEvent
* @see #processMouseEvent
* @see #processMouseMotionEvent
* @see #processInputMethodEvent
* @see #processHierarchyEvent
* @see #processMouseWheelEvent
*/
public
void
eventDispatched
(
AWTEvent
e
,
JLayer
<?
extends
V
>
l
){
if
(
e
instanceof
FocusEvent
)
{
processFocusEvent
((
FocusEvent
)
e
,
l
);
}
else
if
(
e
instanceof
MouseEvent
)
{
switch
(
e
.
getID
())
{
case
MouseEvent
.
MOUSE_PRESSED
:
case
MouseEvent
.
MOUSE_RELEASED
:
case
MouseEvent
.
MOUSE_CLICKED
:
case
MouseEvent
.
MOUSE_ENTERED
:
case
MouseEvent
.
MOUSE_EXITED
:
processMouseEvent
((
MouseEvent
)
e
,
l
);
break
;
case
MouseEvent
.
MOUSE_MOVED
:
case
MouseEvent
.
MOUSE_DRAGGED
:
processMouseMotionEvent
((
MouseEvent
)
e
,
l
);
break
;
case
MouseEvent
.
MOUSE_WHEEL
:
processMouseWheelEvent
((
MouseWheelEvent
)
e
,
l
);
break
;
}
}
else
if
(
e
instanceof
KeyEvent
)
{
processKeyEvent
((
KeyEvent
)
e
,
l
);
}
else
if
(
e
instanceof
ComponentEvent
)
{
processComponentEvent
((
ComponentEvent
)
e
,
l
);
}
else
if
(
e
instanceof
InputMethodEvent
)
{
processInputMethodEvent
((
InputMethodEvent
)
e
,
l
);
}
else
if
(
e
instanceof
HierarchyEvent
)
{
switch
(
e
.
getID
())
{
case
HierarchyEvent
.
HIERARCHY_CHANGED
:
processHierarchyEvent
((
HierarchyEvent
)
e
,
l
);
break
;
case
HierarchyEvent
.
ANCESTOR_MOVED
:
case
HierarchyEvent
.
ANCESTOR_RESIZED
:
processHierarchyBoundsEvent
((
HierarchyEvent
)
e
,
l
);
break
;
}
}
}
/**
* Processes component events occurring on the {@link JLayer}
* or any of its subcomponents.
* <p/>
* This method is not called unless component events are
* enabled for the {@code JLayer} objects, this {@code LayerUI} is set to.
* Component events are enabled in the overridden {@link #installUI} method
* and should be disabled in the {@link #uninstallUI} method after that.
* <pre>
* public void installUI(JComponent c) {
* super.installUI(c);
* JLayer l = (JLayer) c;
* l.setLayerEventMask(AWTEvent.COMPONENT_EVENT_MASK);
* }
*
* public void unistallUI(JComponent c) {
* super.uninstallUI(c);
* JLayer l = (JLayer) c;
* l.setLayerEventMask(0);
* }
* </pre>
*
* @param e the {@code ComponentEvent} to be processed
* @param l the layer this {@code LayerUI} instance is set to
*
* @see JLayer#setLayerEventMask(long)
* @see #installUI(javax.swing.JComponent)
* @see #uninstallUI(javax.swing.JComponent)
*/
protected
void
processComponentEvent
(
ComponentEvent
e
,
JLayer
<?
extends
V
>
l
)
{
}
/**
* Processes focus events occurring on the {@link JLayer}
* or any of its subcomponents.
* <p/>
* This method is not called unless focus events are
* enabled for the {@code JLayer} objects, this {@code LayerUI} is set to.
* Focus events are enabled in the overridden {@link #installUI} method
* and should be disabled in the {@link #uninstallUI} method after that.
* <pre>
* public void installUI(JComponent c) {
* super.installUI(c);
* JLayer l = (JLayer) c;
* l.setLayerEventMask(AWTEvent.FOCUS_EVENT_MASK);
* }
*
* public void unistallUI(JComponent c) {
* super.uninstallUI(c);
* JLayer l = (JLayer) c;
* l.setLayerEventMask(0);
* }
* </pre>
*
* @param e the {@code FocusEvent} to be processed
* @param l the layer this {@code LayerUI} instance is set to
*
* @see JLayer#setLayerEventMask(long)
* @see #installUI(javax.swing.JComponent)
* @see #uninstallUI(javax.swing.JComponent)
*/
protected
void
processFocusEvent
(
FocusEvent
e
,
JLayer
<?
extends
V
>
l
)
{
}
/**
* Processes key events occurring on the {@link JLayer}
* or any of its subcomponents.
* <p/>
* This method is not called unless key events are
* enabled for the {@code JLayer} objects, this {@code LayerUI} is set to.
* Key events are enabled in the overridden {@link #installUI} method
* and should be disabled in the {@link #uninstallUI} method after that.
* <pre>
* public void installUI(JComponent c) {
* super.installUI(c);
* JLayer l = (JLayer) c;
* l.setLayerEventMask(AWTEvent.KEY_EVENT_MASK);
* }
*
* public void unistallUI(JComponent c) {
* super.uninstallUI(c);
* JLayer l = (JLayer) c;
* l.setLayerEventMask(0);
* }
* </pre>
*
* @param e the {@code KeyEvent} to be processed
* @param l the layer this {@code LayerUI} instance is set to
*
* @see JLayer#setLayerEventMask(long)
* @see #installUI(javax.swing.JComponent)
* @see #uninstallUI(javax.swing.JComponent)
*/
protected
void
processKeyEvent
(
KeyEvent
e
,
JLayer
<?
extends
V
>
l
)
{
}
/**
* Processes mouse events occurring on the {@link JLayer}
* or any of its subcomponents.
* <p/>
* This method is not called unless mouse events are
* enabled for the {@code JLayer} objects, this {@code LayerUI} is set to.
* Mouse events are enabled in the overridden {@link #installUI} method
* and should be disabled in the {@link #uninstallUI} method after that.
* <pre>
* public void installUI(JComponent c) {
* super.installUI(c);
* JLayer l = (JLayer) c;
* l.setLayerEventMask(AWTEvent.MOUSE_EVENT_MASK);
* }
*
* public void unistallUI(JComponent c) {
* super.uninstallUI(c);
* JLayer l = (JLayer) c;
* l.setLayerEventMask(0);
* }
* </pre>
*
* @param e the {@code MouseEvent} to be processed
* @param l the layer this {@code LayerUI} instance is set to
*
* @see JLayer#setLayerEventMask(long)
* @see #installUI(javax.swing.JComponent)
* @see #uninstallUI(javax.swing.JComponent)
*/
protected
void
processMouseEvent
(
MouseEvent
e
,
JLayer
<?
extends
V
>
l
)
{
}
/**
* Processes mouse motion event occurring on the {@link JLayer}
* or any of its subcomponents.
* <p/>
* This method is not called unless mouse motion events are
* enabled for the {@code JLayer} objects, this {@code LayerUI} is set to.
* Mouse motion events are enabled in the overridden {@link #installUI} method
* and should be disabled in the {@link #uninstallUI} method after that.
* <pre>
* public void installUI(JComponent c) {
* super.installUI(c);
* JLayer l = (JLayer) c;
* l.setLayerEventMask(AWTEvent.MOUSE_MOTION_EVENT_MASK);
* }
*
* public void unistallUI(JComponent c) {
* super.uninstallUI(c);
* JLayer l = (JLayer) c;
* l.setLayerEventMask(0);
* }
* </pre>
*
* @param e the {@code MouseEvent} to be processed
* @param l the layer this {@code LayerUI} instance is set to
*
* @see JLayer#setLayerEventMask(long)
* @see #installUI(javax.swing.JComponent)
* @see #uninstallUI(javax.swing.JComponent)
*/
protected
void
processMouseMotionEvent
(
MouseEvent
e
,
JLayer
<?
extends
V
>
l
)
{
}
/**
* Processes mouse wheel event occurring on the {@link JLayer}
* or any of its subcomponents.
* <p/>
* This method is not called unless mouse wheel events are
* enabled for the {@code JLayer} objects, this {@code LayerUI} is set to.
* Mouse wheel events are enabled in the overridden {@link #installUI} method
* and should be disabled in the {@link #uninstallUI} method after that.
* <pre>
* public void installUI(JComponent c) {
* super.installUI(c);
* JLayer l = (JLayer) c;
* l.setLayerEventMask(AWTEvent.MOUSE_WHEEL_EVENT_MASK);
* }
*
* public void unistallUI(JComponent c) {
* super.uninstallUI(c);
* JLayer l = (JLayer) c;
* l.setLayerEventMask(0);
* }
* </pre>
*
* @param e the {@code MouseEvent} to be processed
* @param l the layer this {@code LayerUI} instance is set to
*
* @see JLayer#setLayerEventMask(long)
* @see #installUI(javax.swing.JComponent)
* @see #uninstallUI(javax.swing.JComponent)
*/
protected
void
processMouseWheelEvent
(
MouseWheelEvent
e
,
JLayer
<?
extends
V
>
l
)
{
}
/**
* Processes input event occurring on the {@link JLayer}
* or any of its subcomponents.
* <p/>
* This method is not called unless input events are
* enabled for the {@code JLayer} objects, this {@code LayerUI} is set to.
* Input events are enabled in the overridden {@link #installUI} method
* and should be disabled in the {@link #uninstallUI} method after that.
* <pre>
* public void installUI(JComponent c) {
* super.installUI(c);
* JLayer l = (JLayer) c;
* l.setLayerEventMask(AWTEvent.INPUT_METHOD_EVENT_MASK);
* }
*
* public void unistallUI(JComponent c) {
* super.uninstallUI(c);
* JLayer l = (JLayer) c;
* l.setLayerEventMask(0);
* }
* </pre>
*
* @param e the {@code InputMethodEvent} to be processed
* @param l the layer this {@code LayerUI} instance is set to
*
* @see JLayer#setLayerEventMask(long)
* @see #installUI(javax.swing.JComponent)
* @see #uninstallUI(javax.swing.JComponent)
*/
protected
void
processInputMethodEvent
(
InputMethodEvent
e
,
JLayer
<?
extends
V
>
l
)
{
}
/**
* Processes hierarchy event occurring on the {@link JLayer}
* or any of its subcomponents.
* <p/>
* This method is not called unless hierarchy events are
* enabled for the {@code JLayer} objects, this {@code LayerUI} is set to.
* Hierarchy events are enabled in the overridden {@link #installUI} method
* and should be disabled in the {@link #uninstallUI} method after that.
* <pre>
* public void installUI(JComponent c) {
* super.installUI(c);
* JLayer l = (JLayer) c;
* l.setLayerEventMask(AWTEvent.HIERARCHY_EVENT_MASK);
* }
*
* public void unistallUI(JComponent c) {
* super.uninstallUI(c);
* JLayer l = (JLayer) c;
* l.setLayerEventMask(0);
* }
* </pre>
*
* @param e the {@code HierarchyEvent} to be processed
* @param l the layer this {@code LayerUI} instance is set to
*
* @see JLayer#setLayerEventMask(long)
* @see #installUI(javax.swing.JComponent)
* @see #uninstallUI(javax.swing.JComponent)
*/
protected
void
processHierarchyEvent
(
HierarchyEvent
e
,
JLayer
<?
extends
V
>
l
)
{
}
/**
* Processes hierarchy bounds event occurring on the {@link JLayer}
* or any of its subcomponents.
* <p/>
* This method is not called unless hierarchy bounds events are
* enabled for the {@code JLayer} objects, this {@code LayerUI} is set to.
* Hierarchy bounds events are enabled in the overridden {@link #installUI}
* method and should be disabled in the {@link #uninstallUI} method after that.
* <pre>
* public void installUI(JComponent c) {
* super.installUI(c);
* JLayer l = (JLayer) c;
* l.setLayerEventMask(AWTEvent.HIERARCHY_BOUNDS_EVENT_MASK);
* }
*
* public void unistallUI(JComponent c) {
* super.uninstallUI(c);
* JLayer l = (JLayer) c;
* l.setLayerEventMask(0);
* }
* </pre>
*
* @param e the {@code HierarchyEvent} to be processed
* @param l the layer this {@code LayerUI} instance is set to
*
* @see JLayer#setLayerEventMask(long)
* @see #installUI(javax.swing.JComponent)
* @see #uninstallUI(javax.swing.JComponent)
*/
protected
void
processHierarchyBoundsEvent
(
HierarchyEvent
e
,
JLayer
<?
extends
V
>
l
)
{
}
/**
...
...
@@ -250,14 +627,29 @@ public class LayerUI<V extends Component>
propertyChangeSupport
.
firePropertyChange
(
propertyName
,
oldValue
,
newValue
);
}
/**
* Repaints all {@code JLayer} instances this {@code LayerUI} is set to.
* Call this method when the state of this {@code LayerUI} is changed
* and the visual appearance of its {@code JLayer} objects needs to be updated.
*
* @see Component#repaint()
*/
protected
void
repaintLayer
()
{
firePropertyChange
(
"dirty"
,
null
,
null
);
}
/**
* Notifies the {@code LayerUI} when any of its property are changed
* and enables updating every {@code JLayer} this {@code LayerUI} instance is set to.
* and enables updating every {@code JLayer}
* this {@code LayerUI} instance is set to.
*
* @param evt the PropertyChangeEvent generated by this {@code LayerUI}
* @param l the {@code JLayer} this LayerUI is set to
*/
public
void
applyPropertyChange
(
PropertyChangeEvent
evt
,
JLayer
<?
extends
V
>
l
)
{
if
(
"dirty"
.
equals
(
evt
.
getPropertyName
()))
{
l
.
repaint
();
}
}
/**
...
...
src/share/classes/javax/swing/plaf/basic/BasicDirectoryModel.java
浏览文件 @
bf4e9501
...
...
@@ -486,7 +486,7 @@ public class BasicDirectoryModel extends AbstractListModel implements PropertyCh
}
if
(
remSize
>
0
&&
addSize
==
0
)
{
fireIntervalRemoved
(
BasicDirectoryModel
.
this
,
remStart
,
remStart
+
remSize
-
1
);
}
else
if
(
addSize
>
0
&&
remSize
==
0
&&
fileCache
.
size
()
>
addSize
)
{
}
else
if
(
addSize
>
0
&&
remSize
==
0
&&
addStart
+
addSize
<=
fileCache
.
size
()
)
{
fireIntervalAdded
(
BasicDirectoryModel
.
this
,
addStart
,
addStart
+
addSize
-
1
);
}
else
{
fireContentsChanged
();
...
...
src/share/classes/javax/swing/plaf/metal/OceanTheme.java
浏览文件 @
bf4e9501
...
...
@@ -32,6 +32,7 @@ import javax.swing.*;
import
javax.swing.plaf.*
;
import
sun.swing.SwingUtilities2
;
import
sun.swing.PrintColorUIResource
;
import
sun.swing.SwingLazyValue
;
/**
* The default theme for the {@code MetalLookAndFeel}.
...
...
@@ -128,7 +129,7 @@ public class OceanTheme extends DefaultMetalTheme {
* @throws NullPointerException if {@code table} is {@code null}
*/
public
void
addCustomEntriesToTable
(
UIDefaults
table
)
{
Object
focusBorder
=
new
UIDefaults
.
Proxy
LazyValue
(
Object
focusBorder
=
new
Swing
LazyValue
(
"javax.swing.plaf.BorderUIResource$LineBorderUIResource"
,
new
Object
[]
{
getPrimary1
()});
// .30 0 DDE8F3 white secondary2
...
...
src/share/classes/javax/swing/plaf/synth/SynthTableUI.java
浏览文件 @
bf4e9501
...
...
@@ -638,7 +638,7 @@ class SynthTableUI extends BasicTableUI implements SynthUI,
if
((
b
==
null
||
b
instanceof
UIResource
||
component
instanceof
SynthBooleanTableCellRenderer
)
&&
!
table
.
isCellSelected
(
row
,
column
))
{
if
(
alternateColor
!=
null
&&
row
%
2
=
=
0
)
{
if
(
alternateColor
!=
null
&&
row
%
2
!
=
0
)
{
component
.
setBackground
(
alternateColor
);
}
}
...
...
src/share/classes/javax/swing/table/DefaultTableCellRenderer.java
浏览文件 @
bf4e9501
...
...
@@ -214,8 +214,9 @@ public class DefaultTableCellRenderer extends JLabel
:
table
.
getBackground
();
if
(
background
==
null
||
background
instanceof
javax
.
swing
.
plaf
.
UIResource
)
{
Color
alternateColor
=
DefaultLookup
.
getColor
(
this
,
ui
,
"Table.alternateRowColor"
);
if
(
alternateColor
!=
null
&&
row
%
2
==
0
)
if
(
alternateColor
!=
null
&&
row
%
2
!=
0
)
{
background
=
alternateColor
;
}
}
super
.
setForeground
(
unselectedForeground
!=
null
?
unselectedForeground
...
...
src/share/classes/javax/swing/text/JTextComponent.java
浏览文件 @
bf4e9501
...
...
@@ -2069,7 +2069,7 @@ public abstract class JTextComponent extends JComponent implements Scrollable, A
* width to match its own
*/
public
boolean
getScrollableTracksViewportWidth
()
{
JViewport
port
=
SwingUtilities
2
.
ge
tViewport
(
this
);
JViewport
port
=
SwingUtilities
.
getParen
tViewport
(
this
);
if
(
port
!=
null
)
{
return
port
.
getWidth
()
>
getPreferredSize
().
width
;
}
...
...
@@ -2090,7 +2090,7 @@ public abstract class JTextComponent extends JComponent implements Scrollable, A
* to match its own
*/
public
boolean
getScrollableTracksViewportHeight
()
{
JViewport
port
=
SwingUtilities
2
.
ge
tViewport
(
this
);
JViewport
port
=
SwingUtilities
.
getParen
tViewport
(
this
);
if
(
port
!=
null
)
{
return
(
port
.
getHeight
()
>
getPreferredSize
().
height
);
}
...
...
src/share/classes/sun/awt/shell/ShellFolder.java
浏览文件 @
bf4e9501
...
...
@@ -201,6 +201,8 @@ public abstract class ShellFolder extends File {
private
static
ShellFolderManager
shellFolderManager
;
private
static
Invoker
invoker
;
static
{
String
managerClassName
=
(
String
)
Toolkit
.
getDefaultToolkit
().
getDesktopProperty
(
"Shell.shellFolderManager"
);
...
...
@@ -225,6 +227,8 @@ public abstract class ShellFolder extends File {
throw
new
Error
(
"Could not access Shell Folder Manager: "
+
managerClass
.
getName
());
}
invoker
=
shellFolderManager
.
createInvoker
();
}
/**
...
...
@@ -486,21 +490,6 @@ public abstract class ShellFolder extends File {
return
null
;
}
private
static
Invoker
invoker
;
/**
* Provides the single access point to the {@link Invoker}. It is guaranteed that the value
* returned by this method will be always the same.
*
* @return the singleton instance of {@link Invoker}
*/
public
static
Invoker
getInvoker
()
{
if
(
invoker
==
null
)
{
invoker
=
shellFolderManager
.
createInvoker
();
}
return
invoker
;
}
/**
* Invokes the {@code task} which doesn't throw checked exceptions
* from its {@code call} method. If invokation is interrupted then Thread.currentThread().isInterrupted() will
...
...
@@ -522,7 +511,7 @@ public abstract class ShellFolder extends File {
public
static
<
T
,
E
extends
Throwable
>
T
invoke
(
Callable
<
T
>
task
,
Class
<
E
>
exceptionClass
)
throws
InterruptedException
,
E
{
try
{
return
getInvoker
()
.
invoke
(
task
);
return
invoker
.
invoke
(
task
);
}
catch
(
Exception
e
)
{
if
(
e
instanceof
RuntimeException
)
{
// Rethrow unchecked exceptions
...
...
src/share/classes/sun/swing/SwingLazyValue.java
浏览文件 @
bf4e9501
...
...
@@ -26,6 +26,9 @@ package sun.swing;
import
java.lang.reflect.Constructor
;
import
java.lang.reflect.Method
;
import
java.lang.reflect.AccessibleObject
;
import
java.security.AccessController
;
import
java.security.PrivilegedAction
;
import
javax.swing.UIDefaults
;
/**
...
...
@@ -65,13 +68,15 @@ public class SwingLazyValue implements UIDefaults.LazyValue {
if
(
methodName
!=
null
)
{
Class
[]
types
=
getClassArray
(
args
);
Method
m
=
c
.
getMethod
(
methodName
,
types
);
makeAccessible
(
m
);
return
m
.
invoke
(
c
,
args
);
}
else
{
Class
[]
types
=
getClassArray
(
args
);
Constructor
constructor
=
c
.
getConstructor
(
types
);
makeAccessible
(
constructor
);
return
constructor
.
newInstance
(
args
);
}
}
catch
(
Exception
e
)
{
}
catch
(
Exception
e
)
{
// Ideally we would throw an exception, unfortunately
// often times there are errors as an initial look and
// feel is loaded before one can be switched. Perhaps a
...
...
@@ -81,6 +86,15 @@ public class SwingLazyValue implements UIDefaults.LazyValue {
return
null
;
}
private
void
makeAccessible
(
final
AccessibleObject
object
)
{
AccessController
.
doPrivileged
(
new
PrivilegedAction
<
Void
>()
{
public
Void
run
()
{
object
.
setAccessible
(
true
);
return
null
;
}
});
}
private
Class
[]
getClassArray
(
Object
[]
args
)
{
Class
[]
types
=
null
;
if
(
args
!=
null
)
{
...
...
src/share/classes/sun/swing/SwingUtilities2.java
浏览文件 @
bf4e9501
...
...
@@ -1807,22 +1807,4 @@ public class SwingUtilities2 {
boolean
three
)
{
return
liesIn
(
rect
,
p
,
false
,
false
,
three
);
}
/**
* Returns the {@code JViewport} instance for the {@code component}
* or {@code null}.
*
* @return the {@code JViewport} instance for the {@code component}
* or {@code null}
* @throws NullPointerException if {@code component} is {@code null}
*/
public
static
JViewport
getViewport
(
Component
component
)
{
do
{
component
=
component
.
getParent
();
if
(
component
instanceof
JViewport
)
{
return
(
JViewport
)
component
;
}
}
while
(
component
instanceof
JLayer
);
return
null
;
}
}
src/share/classes/sun/util/resources/TimeZoneNames.java
浏览文件 @
bf4e9501
...
...
@@ -141,6 +141,8 @@ public final class TimeZoneNames extends TimeZoneNamesBundle {
"Malaysia Summer Time"
,
"MYST"
};
String
NORONHA
[]
=
new
String
[]
{
"Fernando de Noronha Time"
,
"FNT"
,
"Fernando de Noronha Summer Time"
,
"FNST"
};
String
NOVT
[]
=
new
String
[]
{
"Novosibirsk Time"
,
"NOVT"
,
"Novosibirsk Summer Time"
,
"NOVST"
};
String
NPT
[]
=
new
String
[]
{
"Nepal Time"
,
"NPT"
,
"Nepal Summer Time"
,
"NPST"
};
String
NST
[]
=
new
String
[]
{
"Newfoundland Standard Time"
,
"NST"
,
...
...
@@ -441,7 +443,8 @@ public final class TimeZoneNames extends TimeZoneNamesBundle {
{
"America/Winnipeg"
,
CST
},
{
"America/Yakutat"
,
AKST
},
{
"America/Yellowknife"
,
MST
},
{
"Antarctica/Casey"
,
WST_AUS
},
{
"Antarctica/Casey"
,
new
String
[]
{
"Casey Time"
,
"CAST"
,
"Casey Summer Time"
,
"CAST"
}},
{
"Antarctica/Davis"
,
new
String
[]
{
"Davis Time"
,
"DAVT"
,
"Davis Summer Time"
,
"DAVST"
}},
{
"Antarctica/DumontDUrville"
,
new
String
[]
{
"Dumont-d'Urville Time"
,
"DDUT"
,
...
...
@@ -529,8 +532,8 @@ public final class TimeZoneNames extends TimeZoneNamesBundle {
"Philippines Summer Time"
,
"PHST"
}},
{
"Asia/Muscat"
,
GST
},
{
"Asia/Nicosia"
,
EET
},
{
"Asia/Novo
sibirsk"
,
new
String
[]
{
"Novosibirsk Time"
,
"NOVT"
,
"Novosibirsk Summer Time"
,
"NOVST"
}
},
{
"Asia/Novo
kuznetsk"
,
NOVT
}
,
{
"Asia/Novosibirsk"
,
NOVT
},
{
"Asia/Oral"
,
new
String
[]
{
"Oral Time"
,
"ORAT"
,
"Oral Summer Time"
,
"ORAST"
}},
{
"Asia/Omsk"
,
new
String
[]
{
"Omsk Time"
,
"OMST"
,
...
...
src/share/classes/sun/util/resources/TimeZoneNames_de.java
浏览文件 @
bf4e9501
...
...
@@ -141,6 +141,8 @@ public final class TimeZoneNames_de extends TimeZoneNamesBundle {
"Malaysische Sommerzeit"
,
"MYST"
};
String
NORONHA
[]
=
new
String
[]
{
"Fernando de Noronha Zeit"
,
"FNT"
,
"Fernando de Noronha Sommerzeit"
,
"FNST"
};
String
NOVT
[]
=
new
String
[]
{
"Nowosibirsker Zeit"
,
"NOVT"
,
"Nowosibirsker Sommerzeit"
,
"NOVST"
};
String
NPT
[]
=
new
String
[]
{
"Nepalesische Zeit"
,
"NPT"
,
"Nepalesische Sommerzeit"
,
"NPST"
};
String
NST
[]
=
new
String
[]
{
"Neufundland Normalzeit"
,
"NST"
,
...
...
@@ -441,7 +443,6 @@ public final class TimeZoneNames_de extends TimeZoneNamesBundle {
{
"America/Winnipeg"
,
CST
},
{
"America/Yakutat"
,
AKST
},
{
"America/Yellowknife"
,
MST
},
{
"Antarctica/Casey"
,
WST_AUS
},
{
"Antarctica/Davis"
,
new
String
[]
{
"Davis Zeit"
,
"DAVT"
,
"Davis Sommerzeit"
,
"DAVST"
}},
{
"Antarctica/DumontDUrville"
,
new
String
[]
{
"Dumont-d'Urville Zeit"
,
"DDUT"
,
...
...
@@ -529,8 +530,8 @@ public final class TimeZoneNames_de extends TimeZoneNamesBundle {
"Philippinische Sommerzeit"
,
"PHST"
}},
{
"Asia/Muscat"
,
GST
},
{
"Asia/Nicosia"
,
EET
},
{
"Asia/Novo
sibirsk"
,
new
String
[]
{
"Nowosibirsker Zeit"
,
"NOVT"
,
"Nowosibirsker Sommerzeit"
,
"NOVST"
}
},
{
"Asia/Novo
kuznetsk"
,
NOVT
}
,
{
"Asia/Novosibirsk"
,
NOVT
},
{
"Asia/Oral"
,
new
String
[]
{
"Oral Zeit"
,
"ORAT"
,
"Oral Sommerzeit"
,
"ORAST"
}},
{
"Asia/Omsk"
,
new
String
[]
{
"Omsk Zeit"
,
"OMST"
,
...
...
src/share/classes/sun/util/resources/TimeZoneNames_es.java
浏览文件 @
bf4e9501
...
...
@@ -141,6 +141,8 @@ public final class TimeZoneNames_es extends TimeZoneNamesBundle {
"Hora de verano de Malasia"
,
"MYST"
};
String
NORONHA
[]
=
new
String
[]
{
"Hora de Fernando de Noronha"
,
"FNT"
,
"Hora de verano de Fernando de Noronha"
,
"FNST"
};
String
NOVT
[]
=
new
String
[]
{
"Hora de Novosibirsk"
,
"NOVT"
,
"Hora de verano de Novosibirsk"
,
"NOVST"
};
String
NPT
[]
=
new
String
[]
{
"Hora de Nepal"
,
"NPT"
,
"Hora de verano de Nepal"
,
"NPST"
};
String
NST
[]
=
new
String
[]
{
"Hora est\u00e1ndar de Terranova"
,
"NST"
,
...
...
@@ -441,7 +443,6 @@ public final class TimeZoneNames_es extends TimeZoneNamesBundle {
{
"America/Winnipeg"
,
CST
},
{
"America/Yakutat"
,
AKST
},
{
"America/Yellowknife"
,
MST
},
{
"Antarctica/Casey"
,
WST_AUS
},
{
"Antarctica/Davis"
,
new
String
[]
{
"Hora de Davis"
,
"DAVT"
,
"Hora de verano de Davis"
,
"DAVST"
}},
{
"Antarctica/DumontDUrville"
,
new
String
[]
{
"Hora de Dumont-d'Urville"
,
"DDUT"
,
...
...
@@ -529,8 +530,9 @@ public final class TimeZoneNames_es extends TimeZoneNamesBundle {
"Hora de verano de Filipinas"
,
"PHST"
}},
{
"Asia/Muscat"
,
GST
},
{
"Asia/Nicosia"
,
EET
},
{
"Asia/Novosibirsk"
,
new
String
[]
{
"Hora de Novosibirsk"
,
"NOVT"
,
"Hora de verano de Novosibirsk"
,
"NOVST"
}},
{
"Asia/Novokuznetsk"
,
NOVT
},
{
"Asia/Novosibirsk"
,
NOVT
},
{
"Asia/Oral"
,
new
String
[]
{
"Hora de Uralsk"
,
"ORAT"
,
"Hora de verano de Uralsk"
,
"ORAST"
}},
{
"Asia/Omsk"
,
new
String
[]
{
"Hora de Omsk"
,
"OMST"
,
...
...
src/share/classes/sun/util/resources/TimeZoneNames_fr.java
浏览文件 @
bf4e9501
...
...
@@ -141,6 +141,8 @@ public final class TimeZoneNames_fr extends TimeZoneNamesBundle {
"Heure d'\u00e9t\u00e9 de Malaisie"
,
"MYST"
};
String
NORONHA
[]
=
new
String
[]
{
"Heure de Fernando de Noronha"
,
"FNT"
,
"Heure d'\u00e9t\u00e9 de Fernando de Noronha"
,
"FNST"
};
String
NOVT
[]
=
new
String
[]
{
"Heure de Novossibirsk"
,
"NOVT"
,
"Heure d'\u00e9t\u00e9 de Novossibirsk"
,
"NOVST"
};
String
NPT
[]
=
new
String
[]
{
"Heure du N\u00e9pal"
,
"NPT"
,
"Heure d'\u00e9t\u00e9 du N\u00e9pal"
,
"NPST"
};
String
NST
[]
=
new
String
[]
{
"Heure normale de Terre-Neuve"
,
"NST"
,
...
...
@@ -441,7 +443,6 @@ public final class TimeZoneNames_fr extends TimeZoneNamesBundle {
{
"America/Winnipeg"
,
CST
},
{
"America/Yakutat"
,
AKST
},
{
"America/Yellowknife"
,
MST
},
{
"Antarctica/Casey"
,
WST_AUS
},
{
"Antarctica/Davis"
,
new
String
[]
{
"Heure de Davis"
,
"DAVT"
,
"Heure d'\u00e9t\u00e9 de Davis"
,
"DAVST"
}},
{
"Antarctica/DumontDUrville"
,
new
String
[]
{
"Heure de Dumont-d'Urville"
,
"DDUT"
,
...
...
@@ -529,8 +530,8 @@ public final class TimeZoneNames_fr extends TimeZoneNamesBundle {
"Heure d'\u00e9t\u00e9 des Philippines"
,
"PHST"
}},
{
"Asia/Muscat"
,
GST
},
{
"Asia/Nicosia"
,
EET
},
{
"Asia/Novo
sibirsk"
,
new
String
[]
{
"Heure de Novossibirsk"
,
"NOVT"
,
"Heure d'\u00e9t\u00e9 de Novossibirsk"
,
"NOVST"
}
},
{
"Asia/Novo
kuznetsk"
,
NOVT
}
,
{
"Asia/Novosibirsk"
,
NOVT
},
{
"Asia/Oral"
,
new
String
[]
{
"Heure d'Oral"
,
"ORAT"
,
"Heure d'\u00e9t\u00e9 d'Oral"
,
"ORAST"
}},
{
"Asia/Omsk"
,
new
String
[]
{
"Heure d'Omsk"
,
"OMST"
,
...
...
src/share/classes/sun/util/resources/TimeZoneNames_it.java
浏览文件 @
bf4e9501
...
...
@@ -141,6 +141,8 @@ public final class TimeZoneNames_it extends TimeZoneNamesBundle {
"Ora estiva della Malaysia"
,
"MYST"
};
String
NORONHA
[]
=
new
String
[]
{
"Ora di Fernando de Noronha"
,
"FNT"
,
"Ora estiva di Fernando de Noronha"
,
"FNST"
};
String
NOVT
[]
=
new
String
[]
{
"Ora di Novosibirsk"
,
"NOVT"
,
"Ora estiva di Novosibirsk"
,
"NOVST"
};
String
NPT
[]
=
new
String
[]
{
"Ora del Nepal"
,
"NPT"
,
"Ora estiva del Nepal"
,
"NPST"
};
String
NST
[]
=
new
String
[]
{
"Ora solare di Terranova"
,
"NST"
,
...
...
@@ -441,7 +443,6 @@ public final class TimeZoneNames_it extends TimeZoneNamesBundle {
{
"America/Winnipeg"
,
CST
},
{
"America/Yakutat"
,
AKST
},
{
"America/Yellowknife"
,
MST
},
{
"Antarctica/Casey"
,
WST_AUS
},
{
"Antarctica/Davis"
,
new
String
[]
{
"Ora di Davis"
,
"DAVT"
,
"Ora estiva di Davis"
,
"DAVST"
}},
{
"Antarctica/DumontDUrville"
,
new
String
[]
{
"Ora di Dumont-d'Urville"
,
"DDUT"
,
...
...
@@ -529,8 +530,8 @@ public final class TimeZoneNames_it extends TimeZoneNamesBundle {
"Ora estiva delle Filippine"
,
"PHST"
}},
{
"Asia/Muscat"
,
GST
},
{
"Asia/Nicosia"
,
EET
},
{
"Asia/Novo
sibirsk"
,
new
String
[]
{
"Ora di Novosibirsk"
,
"NOVT"
,
"Ora estiva di Novosibirsk"
,
"NOVST"
}
},
{
"Asia/Novo
kuznetsk"
,
NOVT
}
,
{
"Asia/Novosibirsk"
,
NOVT
},
{
"Asia/Oral"
,
new
String
[]
{
"Ora di Oral"
,
"ORAT"
,
"Ora estiva di Oral"
,
"ORAST"
}},
{
"Asia/Omsk"
,
new
String
[]
{
"Ora di Omsk"
,
"OMST"
,
...
...
src/share/classes/sun/util/resources/TimeZoneNames_ja.java
浏览文件 @
bf4e9501
...
...
@@ -141,6 +141,8 @@ public final class TimeZoneNames_ja extends TimeZoneNamesBundle {
"\u30de\u30ec\u30fc\u30b7\u30a2\u590f\u6642\u9593"
,
"MYST"
};
String
NORONHA
[]
=
new
String
[]
{
"\u30d5\u30a7\u30eb\u30ca\u30f3\u30c9\u30fb\u30c7\u30fb\u30ce\u30ed\u30fc\u30cb\u30e3\u6642\u9593"
,
"FNT"
,
"\u30d5\u30a7\u30eb\u30ca\u30f3\u30c9\u30fb\u30c7\u30fb\u30ce\u30ed\u30fc\u30cb\u30e3\u590f\u6642\u9593"
,
"FNST"
};
String
NOVT
[]
=
new
String
[]
{
"\u30ce\u30dc\u30b7\u30d3\u30eb\u30b9\u30af\u6642\u9593"
,
"NOVT"
,
"\u30ce\u30dc\u30b7\u30d3\u30eb\u30b9\u30af\u590f\u6642\u9593"
,
"NOVST"
};
String
NPT
[]
=
new
String
[]
{
"\u30cd\u30d1\u30fc\u30eb\u6642\u9593"
,
"NPT"
,
"\u30cd\u30d1\u30fc\u30eb\u590f\u6642\u9593"
,
"NPST"
};
String
NST
[]
=
new
String
[]
{
"\u30cb\u30e5\u30fc\u30d5\u30a1\u30f3\u30c9\u30e9\u30f3\u30c9\u6a19\u6e96\u6642"
,
"NST"
,
...
...
@@ -441,7 +443,6 @@ public final class TimeZoneNames_ja extends TimeZoneNamesBundle {
{
"America/Winnipeg"
,
CST
},
{
"America/Yakutat"
,
AKST
},
{
"America/Yellowknife"
,
MST
},
{
"Antarctica/Casey"
,
WST_AUS
},
{
"Antarctica/Davis"
,
new
String
[]
{
"\u30c7\u30a4\u30d3\u30b9\u6642\u9593"
,
"DAVT"
,
"\u30c7\u30a4\u30d3\u30b9\u590f\u6642\u9593"
,
"DAVST"
}},
{
"Antarctica/DumontDUrville"
,
new
String
[]
{
"\u30c7\u30e5\u30e2\u30f3\u30c7\u30e5\u30eb\u30f4\u30a3\u30eb\u6642\u9593"
,
"DDUT"
,
...
...
@@ -529,8 +530,8 @@ public final class TimeZoneNames_ja extends TimeZoneNamesBundle {
"\u30d5\u30a3\u30ea\u30d4\u30f3\u590f\u6642\u9593"
,
"PHST"
}},
{
"Asia/Muscat"
,
GST
},
{
"Asia/Nicosia"
,
EET
},
{
"Asia/Novo
sibirsk"
,
new
String
[]
{
"\u30ce\u30dc\u30b7\u30d3\u30eb\u30b9\u30af\u6642\u9593"
,
"NOVT"
,
"\u30ce\u30dc\u30b7\u30d3\u30eb\u30b9\u30af\u590f\u6642\u9593"
,
"NOVST"
}
},
{
"Asia/Novo
kuznetsk"
,
NOVT
}
,
{
"Asia/Novosibirsk"
,
NOVT
},
{
"Asia/Oral"
,
new
String
[]
{
"\u30aa\u30e9\u30eb\u6642\u9593"
,
"ORAT"
,
"\u30aa\u30e9\u30eb\u590f\u6642\u9593"
,
"ORAST"
}},
{
"Asia/Omsk"
,
new
String
[]
{
"\u30aa\u30e0\u30b9\u30af\u6642\u9593"
,
"OMST"
,
...
...
src/share/classes/sun/util/resources/TimeZoneNames_ko.java
浏览文件 @
bf4e9501
...
...
@@ -141,6 +141,8 @@ public final class TimeZoneNames_ko extends TimeZoneNamesBundle {
"\ub9d0\ub808\uc774\uc2dc\uc544 \uc77c\uad11\uc808\uc57d\uc2dc\uac04"
,
"MYST"
};
String
NORONHA
[]
=
new
String
[]
{
"Fernando de Noronha \uc2dc\uac04"
,
"FNT"
,
"Fernando de Noronha \uc77c\uad11\uc808\uc57d\uc2dc\uac04"
,
"FNST"
};
String
NOVT
[]
=
new
String
[]
{
"\ub178\ube0c\uc2dc\ube4c\uc2a4\ud06c \uc2dc\uac04"
,
"NOVT"
,
"\ub178\ube0c\uc2dc\ube4c\uc2a4\ud06c \uc77c\uad11\uc808\uc57d\uc2dc\uac04"
,
"NOVST"
};
String
NPT
[]
=
new
String
[]
{
"\ub124\ud314 \uc2dc\uac04"
,
"NPT"
,
"\ub124\ud314 \uc77c\uad11\uc808\uc57d\uc2dc\uac04"
,
"NPST"
};
String
NST
[]
=
new
String
[]
{
"\ub274\ud380\ub4e4\ub79c\ub4dc \ud45c\uc900\uc2dc"
,
"NST"
,
...
...
@@ -441,7 +443,6 @@ public final class TimeZoneNames_ko extends TimeZoneNamesBundle {
{
"America/Winnipeg"
,
CST
},
{
"America/Yakutat"
,
AKST
},
{
"America/Yellowknife"
,
MST
},
{
"Antarctica/Casey"
,
WST_AUS
},
{
"Antarctica/Davis"
,
new
String
[]
{
"Davis \uc2dc\uac04"
,
"DAVT"
,
"Davis \uc77c\uad11\uc808\uc57d\uc2dc\uac04"
,
"DAVST"
}},
{
"Antarctica/DumontDUrville"
,
new
String
[]
{
"\ub4a4\ubabd \ub4a4\ub974\ube4c \uc2dc\uac04"
,
"DDUT"
,
...
...
@@ -529,8 +530,8 @@ public final class TimeZoneNames_ko extends TimeZoneNamesBundle {
"\ud544\ub9ac\ud540 \uc77c\uad11\uc808\uc57d\uc2dc\uac04"
,
"PHST"
}},
{
"Asia/Muscat"
,
GST
},
{
"Asia/Nicosia"
,
EET
},
{
"Asia/Novo
sibirsk"
,
new
String
[]
{
"\ub178\ube0c\uc2dc\ube4c\uc2a4\ud06c \uc2dc\uac04"
,
"NOVT"
,
"\ub178\ube0c\uc2dc\ube4c\uc2a4\ud06c \uc77c\uad11\uc808\uc57d\uc2dc\uac04"
,
"NOVST"
}
},
{
"Asia/Novo
kuznetsk"
,
NOVT
}
,
{
"Asia/Novosibirsk"
,
NOVT
},
{
"Asia/Oral"
,
new
String
[]
{
"Oral \ud45c\uc900\uc2dc"
,
"ORAT"
,
"Oral \uc77c\uad11\uc808\uc57d\uc2dc\uac04"
,
"ORAST"
}},
{
"Asia/Omsk"
,
new
String
[]
{
"Omsk \uc2dc\uac04"
,
"OMST"
,
...
...
src/share/classes/sun/util/resources/TimeZoneNames_sv.java
浏览文件 @
bf4e9501
...
...
@@ -141,6 +141,8 @@ public final class TimeZoneNames_sv extends TimeZoneNamesBundle {
"Malaysia, sommartid"
,
"MYST"
};
String
NORONHA
[]
=
new
String
[]
{
"Fernando de Noronha, normaltid"
,
"FNT"
,
"Fernando de Noronha, sommartid"
,
"FNST"
};
String
NOVT
[]
=
new
String
[]
{
"Novosibirsk, normaltid"
,
"NOVT"
,
"Novosibirsk, sommartid"
,
"NOVST"
};
String
NPT
[]
=
new
String
[]
{
"Nepal, normaltid"
,
"NPT"
,
"Nepal, sommartid"
,
"NPST"
};
String
NST
[]
=
new
String
[]
{
"Newfoundland, normaltid"
,
"NST"
,
...
...
@@ -441,7 +443,6 @@ public final class TimeZoneNames_sv extends TimeZoneNamesBundle {
{
"America/Winnipeg"
,
CST
},
{
"America/Yakutat"
,
AKST
},
{
"America/Yellowknife"
,
MST
},
{
"Antarctica/Casey"
,
WST_AUS
},
{
"Antarctica/Davis"
,
new
String
[]
{
"Davis, normaltid"
,
"DAVT"
,
"Davis, sommartid"
,
"DAVST"
}},
{
"Antarctica/DumontDUrville"
,
new
String
[]
{
"Dumont-d'Urville, normaltid"
,
"DDUT"
,
...
...
@@ -529,8 +530,8 @@ public final class TimeZoneNames_sv extends TimeZoneNamesBundle {
"Filippinerna, sommartid"
,
"PHST"
}},
{
"Asia/Muscat"
,
GST
},
{
"Asia/Nicosia"
,
EET
},
{
"Asia/Novo
sibirsk"
,
new
String
[]
{
"Novosibirsk, normaltid"
,
"NOVT"
,
"Novosibirsk, sommartid"
,
"NOVST"
}
},
{
"Asia/Novo
kuznetsk"
,
NOVT
}
,
{
"Asia/Novosibirsk"
,
NOVT
},
{
"Asia/Oral"
,
new
String
[]
{
"Oral, normaltid"
,
"ORAT"
,
"Oral, sommartid"
,
"ORAST"
}},
{
"Asia/Omsk"
,
new
String
[]
{
"Omsk, normaltid"
,
"OMST"
,
...
...
src/share/classes/sun/util/resources/TimeZoneNames_zh_CN.java
浏览文件 @
bf4e9501
...
...
@@ -141,6 +141,8 @@ public final class TimeZoneNames_zh_CN extends TimeZoneNamesBundle {
"\u9a6c\u6765\u897f\u4e9a\u590f\u4ee4\u65f6"
,
"MYST"
};
String
NORONHA
[]
=
new
String
[]
{
"\u8d39\u5c14\u5357\u591a\u5fb7\u8bfa\u7f57\u5c3c\u4e9a\u65f6\u95f4"
,
"FNT"
,
"\u8d39\u5c14\u5357\u591a\u5fb7\u8bfa\u7f57\u5c3c\u4e9a\u590f\u4ee4\u65f6"
,
"FNST"
};
String
NOVT
[]
=
new
String
[]
{
"Novosibirsk \u65f6\u95f4"
,
"NOVT"
,
"Novosibirsk \u590f\u4ee4\u65f6"
,
"NOVST"
};
String
NPT
[]
=
new
String
[]
{
"\u5c3c\u6cca\u5c14\u65f6\u95f4"
,
"NPT"
,
"\u5c3c\u6cca\u5c14\u590f\u4ee4\u65f6"
,
"NPST"
};
String
NST
[]
=
new
String
[]
{
"\u7ebd\u82ac\u5170\u6807\u51c6\u65f6\u95f4"
,
"NST"
,
...
...
@@ -441,7 +443,6 @@ public final class TimeZoneNames_zh_CN extends TimeZoneNamesBundle {
{
"America/Winnipeg"
,
CST
},
{
"America/Yakutat"
,
AKST
},
{
"America/Yellowknife"
,
MST
},
{
"Antarctica/Casey"
,
WST_AUS
},
{
"Antarctica/Davis"
,
new
String
[]
{
"\u6234\u7ef4\u65af\u65f6\u95f4"
,
"DAVT"
,
"\u6234\u7ef4\u65af\u590f\u4ee4\u65f6"
,
"DAVST"
}},
{
"Antarctica/DumontDUrville"
,
new
String
[]
{
"Dumont-d'Urville \u65f6\u95f4"
,
"DDUT"
,
...
...
@@ -529,8 +530,8 @@ public final class TimeZoneNames_zh_CN extends TimeZoneNamesBundle {
"\u83f2\u5f8b\u5bbe\u590f\u4ee4\u65f6"
,
"PHST"
}},
{
"Asia/Muscat"
,
GST
},
{
"Asia/Nicosia"
,
EET
},
{
"Asia/Novo
sibirsk"
,
new
String
[]
{
"Novosibirsk \u65f6\u95f4"
,
"NOVT"
,
"Novosibirsk \u590f\u4ee4\u65f6"
,
"NOVST"
}
},
{
"Asia/Novo
kuznetsk"
,
NOVT
}
,
{
"Asia/Novosibirsk"
,
NOVT
},
{
"Asia/Oral"
,
new
String
[]
{
"Oral \u65f6\u95f4"
,
"ORAT"
,
"Oral \u590f\u4ee4\u65f6"
,
"ORAST"
}},
{
"Asia/Omsk"
,
new
String
[]
{
"\u9102\u6728\u65af\u514b\u65f6\u95f4"
,
"OMST"
,
...
...
src/share/classes/sun/util/resources/TimeZoneNames_zh_TW.java
浏览文件 @
bf4e9501
...
...
@@ -141,6 +141,8 @@ public final class TimeZoneNames_zh_TW extends TimeZoneNamesBundle {
"\u99ac\u4f86\u897f\u4e9e\u590f\u4ee4\u6642\u9593"
,
"MYST"
};
String
NORONHA
[]
=
new
String
[]
{
"\u8cbb\u723e\u5357\u591a-\u8fea\u8afe\u7f85\u5c3c\u4e9e\u6642\u9593"
,
"FNT"
,
"\u8cbb\u723e\u5357\u591a-\u8fea\u8afe\u7f85\u5c3c\u4e9e\u590f\u4ee4\u6642\u9593"
,
"FNST"
};
String
NOVT
[]
=
new
String
[]
{
"Novosibirsk \u6642\u9593"
,
"NOVT"
,
"Novosibirsk \u590f\u4ee4\u6642\u9593"
,
"NOVST"
};
String
NPT
[]
=
new
String
[]
{
"\u5c3c\u6cca\u723e\u6642\u9593"
,
"NPT"
,
"\u5c3c\u6cca\u723e\u590f\u4ee4\u6642\u9593"
,
"NPST"
};
String
NST
[]
=
new
String
[]
{
"\u7d10\u82ac\u862d\u6a19\u6e96\u6642\u9593"
,
"NST"
,
...
...
@@ -441,7 +443,6 @@ public final class TimeZoneNames_zh_TW extends TimeZoneNamesBundle {
{
"America/Winnipeg"
,
CST
},
{
"America/Yakutat"
,
AKST
},
{
"America/Yellowknife"
,
MST
},
{
"Antarctica/Casey"
,
WST_AUS
},
{
"Antarctica/Davis"
,
new
String
[]
{
"\u81fa\u7dad\u65af\u6642\u9593"
,
"DAVT"
,
"\u81fa\u7dad\u65af\u590f\u4ee4\u6642\u9593"
,
"DAVST"
}},
{
"Antarctica/DumontDUrville"
,
new
String
[]
{
"Dumont-d'Urville \u6642\u9593"
,
"DDUT"
,
...
...
@@ -529,8 +530,8 @@ public final class TimeZoneNames_zh_TW extends TimeZoneNamesBundle {
"\u83f2\u5f8b\u8cd3\u590f\u4ee4\u6642\u9593"
,
"PHST"
}},
{
"Asia/Muscat"
,
GST
},
{
"Asia/Nicosia"
,
EET
},
{
"Asia/Novo
sibirsk"
,
new
String
[]
{
"Novosibirsk \u6642\u9593"
,
"NOVT"
,
"Novosibirsk \u590f\u4ee4\u6642\u9593"
,
"NOVST"
}
},
{
"Asia/Novo
kuznetsk"
,
NOVT
}
,
{
"Asia/Novosibirsk"
,
NOVT
},
{
"Asia/Oral"
,
new
String
[]
{
"\u6b50\u4f5b\u6642\u9593"
,
"ORAT"
,
"\u6b50\u4f5b\u590f\u4ee4\u6642\u9593"
,
"ORAST"
}},
{
"Asia/Omsk"
,
new
String
[]
{
"\u6b50\u59c6\u65af\u514b (Omsk) \u6642\u9593"
,
"OMST"
,
...
...
src/solaris/native/sun/awt/gtk2_interface.c
浏览文件 @
bf4e9501
...
...
@@ -637,13 +637,13 @@ gboolean gtk2_load()
if
(
gtk_modules_env
&&
strstr
(
gtk_modules_env
,
"atk-bridge"
)
||
gtk_modules_env
&&
strstr
(
gtk_modules_env
,
"gail"
))
{
gchar
*
tmp_env
=
strdup
(
gtk_modules_env
);
/* the new env will be smaller than the old one */
gchar
*
s
,
*
new_env
=
malloc
(
sizeof
(
ENV_PREFIX
)
+
strlen
(
gtk_modules_env
));
if
(
new_env
!=
NULL
)
{
/* careful, strtok modifies its args */
gchar
*
tmp_env
=
strdup
(
gtk_modules_env
);
strcpy
(
new_env
,
ENV_PREFIX
);
/* strip out 'atk-bridge' and 'gail' */
...
...
src/windows/classes/sun/awt/shell/Win32ShellFolder2.java
浏览文件 @
bf4e9501
...
...
@@ -524,7 +524,7 @@ final class Win32ShellFolder2 extends ShellFolder {
// NOTE: this method uses COM and must be called on the 'COM thread'. See ComInvoker for the details
private
static
native
int
compareIDs
(
long
pParentIShellFolder
,
long
pidl1
,
long
pidl2
);
private
Boolean
cachedIsFileSystem
;
private
volatile
Boolean
cachedIsFileSystem
;
/**
* @return Whether this is a file system shell folder
...
...
@@ -693,29 +693,32 @@ final class Win32ShellFolder2 extends ShellFolder {
ArrayList
<
Win32ShellFolder2
>
list
=
new
ArrayList
<
Win32ShellFolder2
>();
long
pEnumObjects
=
getEnumObjects
(
includeHiddenFiles
);
if
(
pEnumObjects
!=
0
)
{
long
childPIDL
;
int
testedAttrs
=
ATTRIB_FILESYSTEM
|
ATTRIB_FILESYSANCESTOR
;
do
{
childPIDL
=
getNextChild
(
pEnumObjects
);
boolean
releasePIDL
=
true
;
if
(
childPIDL
!=
0
&&
(
getAttributes0
(
pIShellFolder
,
childPIDL
,
testedAttrs
)
&
testedAttrs
)
!=
0
)
{
Win32ShellFolder2
childFolder
;
if
(
Win32ShellFolder2
.
this
.
equals
(
desktop
)
&&
personal
!=
null
&&
pidlsEqual
(
pIShellFolder
,
childPIDL
,
personal
.
disposer
.
relativePIDL
))
{
childFolder
=
personal
;
}
else
{
childFolder
=
new
Win32ShellFolder2
(
Win32ShellFolder2
.
this
,
childPIDL
);
releasePIDL
=
false
;
try
{
long
childPIDL
;
int
testedAttrs
=
ATTRIB_FILESYSTEM
|
ATTRIB_FILESYSANCESTOR
;
do
{
childPIDL
=
getNextChild
(
pEnumObjects
);
boolean
releasePIDL
=
true
;
if
(
childPIDL
!=
0
&&
(
getAttributes0
(
pIShellFolder
,
childPIDL
,
testedAttrs
)
&
testedAttrs
)
!=
0
)
{
Win32ShellFolder2
childFolder
;
if
(
Win32ShellFolder2
.
this
.
equals
(
desktop
)
&&
personal
!=
null
&&
pidlsEqual
(
pIShellFolder
,
childPIDL
,
personal
.
disposer
.
relativePIDL
))
{
childFolder
=
personal
;
}
else
{
childFolder
=
new
Win32ShellFolder2
(
Win32ShellFolder2
.
this
,
childPIDL
);
releasePIDL
=
false
;
}
list
.
add
(
childFolder
);
}
list
.
add
(
childFolder
);
}
if
(
releasePIDL
)
{
releasePIDL
(
childPIDL
);
}
}
while
(
childPIDL
!=
0
&&
!
Thread
.
currentThread
().
isInterrupted
()
);
releaseEnumObjects
(
pEnumObjects
);
if
(
releasePIDL
)
{
releasePIDL
(
childPIDL
);
}
}
while
(
childPIDL
!=
0
&&
!
Thread
.
currentThread
().
isInterrupted
()
);
}
finally
{
releaseEnumObjects
(
pEnumObjects
);
}
}
return
Thread
.
currentThread
().
isInterrupted
()
?
new
File
[
0
]
...
...
@@ -759,7 +762,7 @@ final class Win32ShellFolder2 extends ShellFolder {
},
InterruptedException
.
class
);
}
private
Boolean
cachedIsLink
;
private
volatile
Boolean
cachedIsLink
;
/**
* @return Whether this shell folder is a link
...
...
src/windows/classes/sun/awt/shell/Win32ShellFolderManager2.java
浏览文件 @
bf4e9501
...
...
@@ -79,9 +79,12 @@ public class Win32ShellFolderManager2 extends ShellFolderManager {
// Shouldn't happen but watch for it anyway
throw
new
FileNotFoundException
(
"File "
+
file
.
getAbsolutePath
()
+
" not found"
);
}
Win32ShellFolder2
folder
=
createShellFolderFromRelativePIDL
(
parent
,
pIDL
);
Win32ShellFolder2
.
releasePIDL
(
pIDL
);
return
folder
;
try
{
return
createShellFolderFromRelativePIDL
(
parent
,
pIDL
);
}
finally
{
Win32ShellFolder2
.
releasePIDL
(
pIDL
);
}
}
static
Win32ShellFolder2
createShellFolderFromRelativePIDL
(
Win32ShellFolder2
parent
,
long
pIDL
)
...
...
@@ -269,7 +272,7 @@ public class Win32ShellFolderManager2 extends ShellFolderManager {
Arrays
.
sort
(
secondLevelFolders
);
for
(
File
secondLevelFolder
:
secondLevelFolders
)
{
Win32ShellFolder2
folder
=
(
Win32ShellFolder2
)
secondLevelFolder
;
if
(!
folder
.
isFileSystem
()
||
folder
.
isDirectory
(
))
{
if
(!
folder
.
isFileSystem
()
||
(
folder
.
isDirectory
()
&&
!
folder
.
isLink
()
))
{
folders
.
add
(
folder
);
// Add third level for "My Computer"
if
(
folder
.
equals
(
drives
))
{
...
...
test/java/awt/font/NumericShaper/EqualsTest.java
0 → 100644
浏览文件 @
bf4e9501
/*
* Copyright (c) 2009 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
* CA 95054 USA or visit www.sun.com if you need additional information or
* have any questions.
*/
/*
* @test
* @bug 6842557
* @summary confirm that an instance which is created with new Enum ranges is
* equivalent to another instance which is created with equivalent traditional
* ranges or the same Enum ranges.
*/
import
java.awt.font.NumericShaper
;
import
java.util.EnumSet
;
import
static
java
.
awt
.
font
.
NumericShaper
.*;
public
class
EqualsTest
{
public
static
void
main
(
String
[]
args
)
{
NumericShaper
ns1
=
getContextualShaper
(
ARABIC
|
TAMIL
,
TAMIL
);
NumericShaper
ns2
=
getContextualShaper
(
EnumSet
.
of
(
Range
.
ARABIC
,
Range
.
TAMIL
),
Range
.
TAMIL
);
NumericShaper
ns3
=
getContextualShaper
(
EnumSet
.
of
(
Range
.
ARABIC
,
Range
.
TAMIL
),
Range
.
TAMIL
);
NumericShaper
ns4
=
getContextualShaper
(
EnumSet
.
of
(
Range
.
ARABIC
,
Range
.
TAMIL
),
Range
.
ARABIC
);
if
(!
ns1
.
equals
(
ns2
))
{
throw
new
RuntimeException
(
"ns1 != ns2: ns1="
+
ns1
+
", ns2="
+
ns2
);
}
if
(!
ns2
.
equals
(
ns1
))
{
throw
new
RuntimeException
(
"ns2 != ns1: ns1="
+
ns1
+
", ns2="
+
ns2
);
}
if
(!
ns2
.
equals
(
ns3
))
{
throw
new
RuntimeException
(
"ns2 != ns3: ns2="
+
ns2
+
", ns3="
+
ns3
);
}
if
(
ns1
.
equals
(
ns4
))
{
throw
new
RuntimeException
(
"ns1 == ns4: ns1="
+
ns1
+
", ns4="
+
ns4
);
}
if
(
ns2
.
equals
(
ns4
))
{
throw
new
RuntimeException
(
"ns2 == ns4: ns2="
+
ns2
+
", ns4="
+
ns4
);
}
}
}
test/java/awt/font/NumericShaper/MTTest.java
0 → 100644
浏览文件 @
bf4e9501
/*
* Copyright (c) 2009 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
* CA 95054 USA or visit www.sun.com if you need additional information or
* have any questions.
*/
/*
* @test
* @bug 6843181
* @summary Confirm that NumericShaper is thread-safe.
* @run main/timeout=300/othervm MTTest
*/
import
java.awt.font.NumericShaper
;
import
java.util.Arrays
;
import
java.util.EnumSet
;
import
static
java
.
awt
.
font
.
NumericShaper
.*;
public
class
MTTest
{
static
volatile
boolean
runrun
=
true
;
static
volatile
boolean
err
=
false
;
final
static
String
text
=
"-123 (English) 456.00 (Arabic) \u0641\u0642\u0643 -789 (Thai) \u0e01\u0e33 01.23"
;
static
char
[]
t1
,
t2
;
static
NumericShaper
ns1
,
ns2
,
ns3
,
ns4
;
public
static
void
main
(
String
[]
args
)
{
System
.
out
.
println
(
" original: "
+
text
);
ns1
=
getContextualShaper
(
EnumSet
.
of
(
Range
.
ARABIC
),
Range
.
ARABIC
);
t1
=
text
.
toCharArray
();
ns1
.
shape
(
t1
,
0
,
t1
.
length
);
System
.
out
.
println
(
"expected t1: "
+
String
.
valueOf
(
t1
));
ns2
=
getContextualShaper
(
EnumSet
.
of
(
Range
.
THAI
),
Range
.
THAI
);
t2
=
text
.
toCharArray
();
ns2
.
shape
(
t2
,
0
,
t2
.
length
);
System
.
out
.
println
(
"expected t2: "
+
String
.
valueOf
(
t2
));
ns3
=
getContextualShaper
(
ARABIC
,
ARABIC
);
ns4
=
getContextualShaper
(
THAI
,
THAI
);
Thread
th1
=
new
Thread
(
new
Work
(
ns1
,
t1
));
Thread
th2
=
new
Thread
(
new
Work
(
ns2
,
t2
));
Thread
th3
=
new
Thread
(
new
Work
(
ns1
,
t1
));
Thread
th4
=
new
Thread
(
new
Work
(
ns2
,
t2
));
Thread
th5
=
new
Thread
(
new
Work
(
ns3
,
t1
));
Thread
th6
=
new
Thread
(
new
Work
(
ns4
,
t2
));
Thread
th7
=
new
Thread
(
new
Work
(
ns3
,
t1
));
Thread
th8
=
new
Thread
(
new
Work
(
ns4
,
t2
));
th1
.
start
();
th2
.
start
();
th3
.
start
();
th4
.
start
();
th5
.
start
();
th6
.
start
();
th7
.
start
();
th8
.
start
();
try
{
for
(
int
i
=
0
;
runrun
&&
i
<
180
;
i
++)
{
Thread
.
sleep
(
1000
);
// 1 seconds
}
runrun
=
false
;
th1
.
join
();
th2
.
join
();
th3
.
join
();
th4
.
join
();
th5
.
join
();
th6
.
join
();
th7
.
join
();
th8
.
join
();
}
catch
(
InterruptedException
e
)
{
}
if
(
err
)
{
throw
new
RuntimeException
(
"Thread-safe test failed."
);
}
}
private
static
class
Work
implements
Runnable
{
NumericShaper
ns
;
char
[]
expectedText
;
Work
(
NumericShaper
ns
,
char
[]
expectedText
)
{
this
.
ns
=
ns
;
this
.
expectedText
=
expectedText
;
}
public
void
run
()
{
int
count
=
0
;
while
(
runrun
)
{
char
[]
t
=
text
.
toCharArray
();
try
{
count
++;
ns
.
shape
(
t
,
0
,
t
.
length
);
}
catch
(
Exception
e
)
{
System
.
err
.
println
(
"Error: Unexpected exception: "
+
e
);
runrun
=
false
;
err
=
true
;
return
;
}
if
(!
Arrays
.
equals
(
t
,
expectedText
))
{
System
.
err
.
println
(
"Error: shape() returned unexpected value: "
);
System
.
err
.
println
(
"count = "
+
count
);
System
.
err
.
println
(
" expected: "
+
String
.
valueOf
(
expectedText
));
System
.
err
.
println
(
" got: "
+
String
.
valueOf
(
t
));
runrun
=
false
;
err
=
true
;
return
;
}
}
}
}
}
test/java/awt/font/NumericShaper/ShapingTest.java
0 → 100644
浏览文件 @
bf4e9501
/*
* Copyright (c) 2009 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
* CA 95054 USA or visit www.sun.com if you need additional information or
* have any questions.
*/
/*
* @test
* @bug 6842557
* @summary confirm that shaping works as expected. (Mainly for new characters which were added in Unicode 5)
* used where appropriate.
*/
import
java.awt.font.NumericShaper
;
import
java.util.EnumSet
;
import
static
java
.
awt
.
font
.
NumericShaper
.*;
public
class
ShapingTest
{
public
static
void
main
(
String
[]
args
)
{
NumericShaper
ns_old
=
getContextualShaper
(
ARABIC
|
TAMIL
|
ETHIOPIC
,
EUROPEAN
);
NumericShaper
ns_new
=
getContextualShaper
(
EnumSet
.
of
(
Range
.
ARABIC
,
Range
.
TAMIL
,
Range
.
ETHIOPIC
),
Range
.
EUROPEAN
);
boolean
err
=
false
;
String
[][]
data
=
{
// Arabic "October 10"
{
"\u0623\u0643\u062a\u0648\u0628\u0631 10"
,
"\u0623\u0643\u062a\u0648\u0628\u0631 \u0661\u0660"
},
// Tamil "Year 2009"
{
"\u0b86\u0ba3\u0bcd\u0b9f\u0bc1 2009"
,
"\u0b86\u0ba3\u0bcd\u0b9f\u0bc1 \u0be8\u0be6\u0be6\u0bef"
},
// "\u0be800\u0bef is returned by pre-JDK7 because Tamil zero was not
// included in Unicode 4.0.0.
// Ethiopic "Syllable<HA> 2009"
{
"\u1200 2009"
,
"\u1200 \u136a00\u1371"
},
// Ethiopic zero doesn't exist even in Unicode 5.1.0.
};
for
(
int
i
=
0
;
i
<
data
.
length
;
i
++)
{
String
expected
=
data
[
i
][
1
];
char
[]
text
=
data
[
i
][
0
].
toCharArray
();
ns_old
.
shape
(
text
,
0
,
text
.
length
);
String
got
=
new
String
(
text
);
if
(!
expected
.
equals
(
got
))
{
err
=
true
;
System
.
err
.
println
(
"Error with traditional range."
);
System
.
err
.
println
(
" text = "
+
data
[
i
][
0
]);
System
.
err
.
println
(
" got = "
+
got
);
System
.
err
.
println
(
" expected = "
+
expected
);
}
else
{
System
.
err
.
println
(
"OK with traditional range."
);
System
.
err
.
println
(
" text = "
+
data
[
i
][
0
]);
System
.
err
.
println
(
" got = "
+
got
);
System
.
err
.
println
(
" expected = "
+
expected
);
}
text
=
data
[
i
][
0
].
toCharArray
();
ns_new
.
shape
(
text
,
0
,
text
.
length
);
got
=
new
String
(
text
);
if
(!
expected
.
equals
(
got
))
{
err
=
true
;
System
.
err
.
println
(
"Error with new Enum range."
);
System
.
err
.
println
(
" text = "
+
data
[
i
][
0
]);
System
.
err
.
println
(
" got = "
+
got
);
System
.
err
.
println
(
" expected = "
+
expected
);
}
else
{
System
.
err
.
println
(
"OK with new Enum range."
);
System
.
err
.
println
(
" text = "
+
data
[
i
][
0
]);
System
.
err
.
println
(
" got = "
+
got
);
System
.
err
.
println
(
" expected = "
+
expected
);
}
}
if
(
err
)
{
throw
new
RuntimeException
(
"shape() returned unexpected value."
);
}
}
}
test/javax/swing/JFileChooser/6550546/bug6550546.java
0 → 100644
浏览文件 @
bf4e9501
/*
* Copyright 2009 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
* CA 95054 USA or visit www.sun.com if you need additional information or
* have any questions.
*/
/* @test
@bug 6550546
@summary Win LAF: JFileChooser -> Look in Drop down should not display any shortcuts created on desktop
@author Pavel Porvatov
@run main bug6550546
*/
import
sun.awt.OSInfo
;
import
sun.awt.shell.ShellFolder
;
import
javax.swing.*
;
import
java.io.File
;
public
class
bug6550546
{
public
static
void
main
(
String
[]
args
)
throws
Exception
{
if
(
OSInfo
.
getOSType
()
!=
OSInfo
.
OSType
.
WINDOWS
)
{
System
.
out
.
println
(
"The test is suitable only for Windows, skipped."
);
return
;
}
SwingUtilities
.
invokeAndWait
(
new
Runnable
()
{
public
void
run
()
{
File
[]
files
=
(
File
[])
ShellFolder
.
get
(
"fileChooserComboBoxFolders"
);
for
(
File
file
:
files
)
{
if
(
file
instanceof
ShellFolder
&&
((
ShellFolder
)
file
).
isLink
())
{
throw
new
RuntimeException
(
"Link shouldn't be in FileChooser combobox, "
+
file
.
getPath
());
}
}
}
});
}
}
test/javax/swing/JFileChooser/6741890/bug6741890.java
0 → 100644
浏览文件 @
bf4e9501
/*
* Copyright 2009 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
* CA 95054 USA or visit www.sun.com if you need additional information or
* have any questions.
*/
/* @test
@bug 6741890
@summary Deadlock in Win32ShellFolderManager2
@author Pavel Porvatov
@run main bug6741890
*/
import
sun.awt.shell.ShellFolder
;
import
sun.awt.OSInfo
;
import
java.io.File
;
import
java.lang.reflect.Field
;
import
java.util.concurrent.Callable
;
public
class
bug6741890
{
/**
* This mux is used to prevent NPE in the isLink and isFileSystem methods
*/
private
static
final
Object
mux
=
new
Object
();
private
static
final
int
COUNT
=
100000
;
public
static
void
main
(
String
[]
args
)
throws
Exception
{
if
(
OSInfo
.
getOSType
()
!=
OSInfo
.
OSType
.
WINDOWS
)
{
System
.
out
.
println
(
"The test is applicable only for Windows. Skipped."
);
return
;
}
String
tmpDir
=
System
.
getProperty
(
"java.io.tmpdir"
);
if
(
tmpDir
.
length
()
==
0
)
{
//'java.io.tmpdir' isn't guaranteed to be defined
tmpDir
=
System
.
getProperty
(
"user.home"
);
}
final
ShellFolder
tmpFile
=
ShellFolder
.
getShellFolder
(
new
File
(
tmpDir
));
System
.
out
.
println
(
"Temp directory: "
+
tmpDir
);
System
.
out
.
println
(
"Stress test was run"
);
Thread
thread
=
new
Thread
()
{
public
void
run
()
{
while
(!
isInterrupted
())
{
ShellFolder
.
invoke
(
new
Callable
<
Void
>()
{
public
Void
call
()
throws
Exception
{
synchronized
(
mux
)
{
tmpFile
.
isFileSystem
();
tmpFile
.
isLink
();
}
return
null
;
}
});
}
}
};
thread
.
start
();
for
(
int
i
=
0
;
i
<
COUNT
;
i
++)
{
synchronized
(
mux
)
{
clearField
(
tmpFile
,
"cachedIsLink"
);
clearField
(
tmpFile
,
"cachedIsFileSystem"
);
}
tmpFile
.
isFileSystem
();
tmpFile
.
isLink
();
}
thread
.
interrupt
();
thread
.
join
();
System
.
out
.
println
(
"Test passed successfully"
);
}
private
static
void
clearField
(
Object
o
,
String
fieldName
)
throws
Exception
{
Field
field
=
o
.
getClass
().
getDeclaredField
(
fieldName
);
field
.
setAccessible
(
true
);
field
.
set
(
o
,
null
);
}
}
test/javax/swing/JFileChooser/6868611/bug6868611.java
0 → 100644
浏览文件 @
bf4e9501
/*
* Copyright 2009 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
* CA 95054 USA or visit www.sun.com if you need additional information or
* have any questions.
*/
/* @test
@bug 6868611
@summary FileSystemView throws NullPointerException
@author Pavel Porvatov
@run main bug6868611
*/
import
javax.swing.*
;
import
javax.swing.filechooser.FileSystemView
;
import
java.io.File
;
public
class
bug6868611
{
private
static
final
int
COUNT
=
1000
;
public
static
void
main
(
String
[]
args
)
throws
Exception
{
String
tempDirProp
=
System
.
getProperty
(
"java.io.tmpdir"
);
final
String
tempDir
=
tempDirProp
==
null
||
!
new
File
(
tempDirProp
).
isDirectory
()
?
System
.
getProperty
(
"user.home"
)
:
tempDirProp
;
System
.
out
.
println
(
"Temp directory: "
+
tempDir
);
// Create 1000 files
for
(
int
i
=
0
;
i
<
1000
;
i
++)
{
new
File
(
tempDir
,
"temp"
+
i
).
createNewFile
();
}
// Init default FileSystemView
SwingUtilities
.
invokeAndWait
(
new
Runnable
()
{
public
void
run
()
{
FileSystemView
.
getFileSystemView
().
getFiles
(
new
File
(
tempDir
),
false
);
}
});
for
(
int
i
=
0
;
i
<
COUNT
;
i
++)
{
Thread
thread
=
new
MyThread
(
tempDir
);
thread
.
start
();
Thread
.
sleep
((
long
)
(
Math
.
random
()
*
100
));
thread
.
interrupt
();
if
(
i
%
100
==
0
)
{
System
.
out
.
print
(
"*"
);
}
}
System
.
out
.
println
();
// Remove 1000 files
for
(
int
i
=
0
;
i
<
1000
;
i
++)
{
new
File
(
tempDir
,
"temp"
+
i
).
delete
();
}
}
private
static
class
MyThread
extends
Thread
{
private
final
String
dir
;
private
MyThread
(
String
dir
)
{
this
.
dir
=
dir
;
}
public
void
run
()
{
FileSystemView
fileSystemView
=
FileSystemView
.
getFileSystemView
();
fileSystemView
.
getFiles
(
new
File
(
dir
),
false
);
}
}
}
test/javax/swing/UIDefaults/6795356/SwingLazyValueTest.java
0 → 100644
浏览文件 @
bf4e9501
/*
* Copyright 2009 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
* CA 95054 USA or visit www.sun.com if you need additional information or
* have any questions.
*/
/*
* @test
* @bug 6795356
* @summary Checks that SwingLazyValue class correclty works
* @author Alexander Potochkin
* @run main SwingLazyValueTest
*/
import
sun.swing.SwingLazyValue
;
import
javax.swing.*
;
public
class
SwingLazyValueTest
{
public
static
void
main
(
String
[]
args
)
throws
Exception
{
if
(
new
SwingLazyValue
(
"javax.swing.JTable$DoubleRenderer"
).
createValue
(
null
)
==
null
)
{
throw
new
RuntimeException
(
"SwingLazyValue doesn't work"
);
}
}
}
test/javax/swing/UIDefaults/6795356/TableTest.java
0 → 100644
浏览文件 @
bf4e9501
/*
* Copyright 2009 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
* CA 95054 USA or visit www.sun.com if you need additional information or
* have any questions.
*/
/*
* @test
* @bug 6795356
* @summary Checks that SwingLazyValue class correclty works
* @author Alexander Potochkin
* @run main/othervm TableTest
*/
import
sun.applet.AppletSecurity
;
import
javax.swing.*
;
import
javax.swing.table.TableCellEditor
;
import
java.awt.*
;
public
class
TableTest
{
public
static
void
main
(
String
[]
args
)
throws
Exception
{
KeyboardFocusManager
.
getCurrentKeyboardFocusManager
();
System
.
setSecurityManager
(
new
AppletSecurity
());
JTable
table
=
new
JTable
();
TableCellEditor
de
=
table
.
getDefaultEditor
(
Double
.
class
);
if
(
de
==
null
)
{
throw
new
RuntimeException
(
"Table default editor is null"
);
}
}
}
test/javax/swing/UIDefaults/6795356/bug6795356.java
0 → 100644
浏览文件 @
bf4e9501
/*
* Copyright 2009 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
* CA 95054 USA or visit www.sun.com if you need additional information or
* have any questions.
*/
/*
* @test
* @bug 6795356
* @summary Leak caused by javax.swing.UIDefaults.ProxyLazyValue.acc
* @author Alexander Potochkin
* @run main bug6795356
*/
import
java.lang.ref.WeakReference
;
import
java.security.ProtectionDomain
;
import
java.security.AccessController
;
import
java.security.PrivilegedAction
;
import
java.security.AccessControlContext
;
import
java.util.LinkedList
;
import
java.util.List
;
import
javax.swing.*
;
public
class
bug6795356
{
volatile
static
WeakReference
<
ProtectionDomain
>
weakRef
;
public
static
void
main
(
String
[]
args
)
throws
Exception
{
ProtectionDomain
domain
=
new
ProtectionDomain
(
null
,
null
);
AccessController
.
doPrivileged
(
new
PrivilegedAction
<
Object
>()
{
public
Object
run
()
{
// this initialize ProxyLazyValues
UIManager
.
getLookAndFeel
();
return
null
;
}
},
new
AccessControlContext
(
new
ProtectionDomain
[]{
domain
}));
weakRef
=
new
WeakReference
<
ProtectionDomain
>(
domain
);
domain
=
null
;
// Generate OutOfMemory and check the weak ref
generateOOME
();
if
(
weakRef
.
get
()
!=
null
)
{
throw
new
RuntimeException
(
"Memory leak found!"
);
}
System
.
out
.
println
(
"Test passed"
);
}
static
void
generateOOME
()
{
List
<
Object
>
bigLeak
=
new
LinkedList
<
Object
>();
boolean
oome
=
false
;
System
.
out
.
print
(
"Filling the heap"
);
try
{
for
(
int
i
=
0
;
true
;
i
++)
{
// Now, use up all RAM
bigLeak
.
add
(
new
byte
[
1024
*
1024
]);
System
.
out
.
print
(
"."
);
// Give the GC a change at that weakref
if
(
i
%
10
==
0
)
{
System
.
gc
();
try
{
Thread
.
sleep
(
100
);
}
catch
(
InterruptedException
e
)
{
e
.
printStackTrace
();
}
}
}
}
catch
(
OutOfMemoryError
e
)
{
bigLeak
=
null
;
oome
=
true
;
}
System
.
out
.
println
(
""
);
if
(!
oome
)
{
throw
new
RuntimeException
(
"Problem with test case - never got OOME"
);
}
System
.
out
.
println
(
"Got OOME"
);
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录