Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_langtools
提交
98f823a6
D
dragonwell8_langtools
项目概览
openanolis
/
dragonwell8_langtools
通知
0
Star
2
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
dragonwell8_langtools
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
98f823a6
编写于
8月 26, 2008
作者:
J
jjg
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
6508981: cleanup file separator handling in JavacFileManager
Reviewed-by: mcimadamore
上级
f8cd7552
变更
11
展开全部
隐藏空白更改
内联
并排
Showing
11 changed file
with
672 addition
and
296 deletion
+672
-296
src/share/classes/com/sun/tools/javac/file/JavacFileManager.java
...re/classes/com/sun/tools/javac/file/JavacFileManager.java
+54
-78
src/share/classes/com/sun/tools/javac/file/RelativePath.java
src/share/classes/com/sun/tools/javac/file/RelativePath.java
+191
-0
src/share/classes/com/sun/tools/javac/file/SymbolArchive.java
...share/classes/com/sun/tools/javac/file/SymbolArchive.java
+40
-12
src/share/classes/com/sun/tools/javac/file/ZipArchive.java
src/share/classes/com/sun/tools/javac/file/ZipArchive.java
+35
-25
src/share/classes/com/sun/tools/javac/file/ZipFileIndex.java
src/share/classes/com/sun/tools/javac/file/ZipFileIndex.java
+126
-154
src/share/classes/com/sun/tools/javac/file/ZipFileIndexArchive.java
...classes/com/sun/tools/javac/file/ZipFileIndexArchive.java
+18
-19
src/share/classes/com/sun/tools/javadoc/DocletInvoker.java
src/share/classes/com/sun/tools/javadoc/DocletInvoker.java
+1
-0
src/share/classes/javax/tools/StandardLocation.java
src/share/classes/javax/tools/StandardLocation.java
+0
-2
test/tools/javac/6508981/TestInferBinaryName.java
test/tools/javac/6508981/TestInferBinaryName.java
+177
-0
test/tools/javac/6508981/p/A.java
test/tools/javac/6508981/p/A.java
+24
-0
test/tools/javac/T6725036.java
test/tools/javac/T6725036.java
+6
-6
未找到文件。
src/share/classes/com/sun/tools/javac/file/JavacFileManager.java
浏览文件 @
98f823a6
...
...
@@ -65,6 +65,8 @@ import javax.tools.JavaFileObject;
import
javax.tools.StandardJavaFileManager
;
import
com.sun.tools.javac.code.Source
;
import
com.sun.tools.javac.file.RelativePath.RelativeFile
;
import
com.sun.tools.javac.file.RelativePath.RelativeDirectory
;
import
com.sun.tools.javac.main.JavacOption
;
import
com.sun.tools.javac.main.OptionName
;
import
com.sun.tools.javac.main.RecognizedOptions
;
...
...
@@ -75,8 +77,8 @@ import com.sun.tools.javac.util.ListBuffer;
import
com.sun.tools.javac.util.Log
;
import
com.sun.tools.javac.util.Options
;
import
static
com
.
sun
.
tools
.
javac
.
main
.
OptionName
.*;
import
static
javax
.
tools
.
StandardLocation
.*;
import
static
com
.
sun
.
tools
.
javac
.
main
.
OptionName
.*;
/**
* This class provides access to the source, class and other files
...
...
@@ -84,9 +86,6 @@ import static javax.tools.StandardLocation.*;
*/
public
class
JavacFileManager
implements
StandardJavaFileManager
{
private
static
final
String
[]
symbolFileLocation
=
{
"lib"
,
"ct.sym"
};
private
static
final
String
symbolFilePrefix
=
"META-INF/sym/rt.jar/"
;
boolean
useZipFileIndex
;
private
static
boolean
CHECK_ZIP_TIMESTAMP
=
false
;
...
...
@@ -267,6 +266,7 @@ public class JavacFileManager implements StandardJavaFileManager {
printAscii
(
"Invalid class name: \"%s\""
,
name
);
}
}
private
static
void
printAscii
(
String
format
,
Object
...
args
)
{
String
message
;
try
{
...
...
@@ -278,27 +278,12 @@ public class JavacFileManager implements StandardJavaFileManager {
System
.
out
.
println
(
message
);
}
/** Return external representation of name,
* converting '.' to File.separatorChar.
*/
private
static
String
externalizeFileName
(
CharSequence
name
)
{
return
name
.
toString
().
replace
(
'.'
,
File
.
separatorChar
);
}
private
static
String
externalizeFileName
(
CharSequence
n
,
JavaFileObject
.
Kind
kind
)
{
return
externalizeFileName
(
n
)
+
kind
.
extension
;
}
private
static
String
baseName
(
String
fileName
)
{
return
fileName
.
substring
(
fileName
.
lastIndexOf
(
File
.
separatorChar
)
+
1
);
}
/**
* Insert all files in subdirectory `subdirectory' of `directory' which end
* in one of the extensions in `extensions' into packageSym.
*/
private
void
listDirectory
(
File
directory
,
String
subdirectory
,
RelativeDirectory
subdirectory
,
Set
<
JavaFileObject
.
Kind
>
fileKinds
,
boolean
recurse
,
ListBuffer
<
JavaFileObject
>
l
)
{
...
...
@@ -329,22 +314,6 @@ public class JavacFileManager implements StandardJavaFileManager {
return
;
}
}
if
(
subdirectory
.
length
()
!=
0
)
{
if
(!
useZipFileIndex
)
{
subdirectory
=
subdirectory
.
replace
(
'\\'
,
'/'
);
if
(!
subdirectory
.
endsWith
(
"/"
))
subdirectory
=
subdirectory
+
"/"
;
}
else
{
if
(
File
.
separatorChar
==
'/'
)
{
subdirectory
=
subdirectory
.
replace
(
'\\'
,
'/'
);
}
else
{
subdirectory
=
subdirectory
.
replace
(
'/'
,
'\\'
);
}
if
(!
subdirectory
.
endsWith
(
File
.
separator
))
subdirectory
=
subdirectory
+
File
.
separator
;
}
}
List
<
String
>
files
=
archive
.
getFiles
(
subdirectory
);
if
(
files
!=
null
)
{
...
...
@@ -356,8 +325,8 @@ public class JavacFileManager implements StandardJavaFileManager {
}
}
if
(
recurse
)
{
for
(
String
s:
archive
.
getSubdirectories
())
{
if
(
s
.
startsWith
(
subdirectory
)
&&
!
s
.
equals
(
subdirectory
))
{
for
(
RelativeDirectory
s:
archive
.
getSubdirectories
())
{
if
(
s
ubdirectory
.
contains
(
s
))
{
// Because the archive map is a flat list of directories,
// the enclosing loop will pick up all child subdirectories.
// Therefore, there is no need to recurse deeper.
...
...
@@ -366,9 +335,7 @@ public class JavacFileManager implements StandardJavaFileManager {
}
}
}
else
{
File
d
=
subdirectory
.
length
()
!=
0
?
new
File
(
directory
,
subdirectory
)
:
directory
;
File
d
=
subdirectory
.
getFile
(
directory
);
if
(!
caseMapCheck
(
d
,
subdirectory
))
return
;
...
...
@@ -381,7 +348,7 @@ public class JavacFileManager implements StandardJavaFileManager {
if
(
f
.
isDirectory
())
{
if
(
recurse
&&
SourceVersion
.
isIdentifier
(
fname
))
{
listDirectory
(
directory
,
subdirectory
+
File
.
separator
+
fname
,
new
RelativeDirectory
(
subdirectory
,
fname
)
,
fileKinds
,
recurse
,
l
);
...
...
@@ -411,7 +378,7 @@ public class JavacFileManager implements StandardJavaFileManager {
* ends in a string of characters with the same case as given name.
* Ignore file separators in both path and name.
*/
private
boolean
caseMapCheck
(
File
f
,
String
name
)
{
private
boolean
caseMapCheck
(
File
f
,
RelativePath
name
)
{
if
(
fileSystemIsCaseSensitive
)
return
true
;
// Note that getCanonicalPath() returns the case-sensitive
// spelled file name.
...
...
@@ -422,12 +389,12 @@ public class JavacFileManager implements StandardJavaFileManager {
return
false
;
}
char
[]
pcs
=
path
.
toCharArray
();
char
[]
ncs
=
name
.
toCharArray
();
char
[]
ncs
=
name
.
path
.
toCharArray
();
int
i
=
pcs
.
length
-
1
;
int
j
=
ncs
.
length
-
1
;
while
(
i
>=
0
&&
j
>=
0
)
{
while
(
i
>=
0
&&
pcs
[
i
]
==
File
.
separatorChar
)
i
--;
while
(
j
>=
0
&&
ncs
[
j
]
==
File
.
separatorChar
)
j
--;
while
(
j
>=
0
&&
ncs
[
j
]
==
'/'
)
j
--;
if
(
i
>=
0
&&
j
>=
0
)
{
if
(
pcs
[
i
]
!=
ncs
[
j
])
return
false
;
i
--;
...
...
@@ -444,13 +411,13 @@ public class JavacFileManager implements StandardJavaFileManager {
public
interface
Archive
{
void
close
()
throws
IOException
;
boolean
contains
(
String
name
);
boolean
contains
(
RelativePath
name
);
JavaFileObject
getFileObject
(
String
subdirectory
,
String
file
);
JavaFileObject
getFileObject
(
RelativeDirectory
subdirectory
,
String
file
);
List
<
String
>
getFiles
(
String
subdirectory
);
List
<
String
>
getFiles
(
RelativeDirectory
subdirectory
);
Set
<
String
>
getSubdirectories
();
Set
<
RelativeDirectory
>
getSubdirectories
();
}
public
class
MissingArchive
implements
Archive
{
...
...
@@ -458,30 +425,38 @@ public class JavacFileManager implements StandardJavaFileManager {
public
MissingArchive
(
File
name
)
{
zipFileName
=
name
;
}
public
boolean
contains
(
String
name
)
{
public
boolean
contains
(
RelativePath
name
)
{
return
false
;
}
public
void
close
()
{
}
public
JavaFileObject
getFileObject
(
String
subdirectory
,
String
file
)
{
public
JavaFileObject
getFileObject
(
RelativeDirectory
subdirectory
,
String
file
)
{
return
null
;
}
public
List
<
String
>
getFiles
(
String
subdirectory
)
{
public
List
<
String
>
getFiles
(
RelativeDirectory
subdirectory
)
{
return
List
.
nil
();
}
public
Set
<
String
>
getSubdirectories
()
{
public
Set
<
RelativeDirectory
>
getSubdirectories
()
{
return
Collections
.
emptySet
();
}
public
String
toString
()
{
return
"MissingArchive["
+
zipFileName
+
"]"
;
}
}
/** A directory of zip files already opened.
*/
Map
<
File
,
Archive
>
archives
=
new
HashMap
<
File
,
Archive
>();
private
static
final
String
[]
symbolFileLocation
=
{
"lib"
,
"ct.sym"
};
private
static
final
RelativeDirectory
symbolFilePrefix
=
new
RelativeDirectory
(
"META-INF/sym/rt.jar/"
);
/** Open a new zip file directory.
*/
protected
Archive
openArchive
(
File
zipFileName
)
throws
IOException
{
...
...
@@ -540,8 +515,12 @@ public class JavacFileManager implements StandardJavaFileManager {
if
(!
useZipFileIndex
)
{
archive
=
new
ZipArchive
(
this
,
zdir
);
}
else
{
archive
=
new
ZipFileIndexArchive
(
this
,
ZipFileIndex
.
getZipFileIndex
(
zipFileName
,
null
,
usePreindexedCache
,
preindexCacheLocation
,
options
.
get
(
"writezipindexfiles"
)
!=
null
));
archive
=
new
ZipFileIndexArchive
(
this
,
ZipFileIndex
.
getZipFileIndex
(
zipFileName
,
null
,
usePreindexedCache
,
preindexCacheLocation
,
options
.
get
(
"writezipindexfiles"
)
!=
null
));
}
}
else
{
...
...
@@ -551,10 +530,10 @@ public class JavacFileManager implements StandardJavaFileManager {
else
{
archive
=
new
ZipFileIndexArchive
(
this
,
ZipFileIndex
.
getZipFileIndex
(
zipFileName
,
symbolFilePrefix
,
usePreindexedCache
,
preindexCacheLocation
,
options
.
get
(
"writezipindexfiles"
)
!=
null
));
symbolFilePrefix
,
usePreindexedCache
,
preindexCacheLocation
,
options
.
get
(
"writezipindexfiles"
)
!=
null
));
}
}
}
catch
(
FileNotFoundException
ex
)
{
...
...
@@ -796,7 +775,7 @@ public class JavacFileManager implements StandardJavaFileManager {
Iterable
<?
extends
File
>
path
=
getLocation
(
location
);
if
(
path
==
null
)
return
List
.
nil
();
String
subdirectory
=
externalizeFileNam
e
(
packageName
);
RelativeDirectory
subdirectory
=
RelativeDirectory
.
forPackag
e
(
packageName
);
ListBuffer
<
JavaFileObject
>
results
=
new
ListBuffer
<
JavaFileObject
>();
for
(
File
directory
:
path
)
...
...
@@ -877,7 +856,7 @@ public class JavacFileManager implements StandardJavaFileManager {
nullCheck
(
kind
);
if
(!
sourceOrClass
.
contains
(
kind
))
throw
new
IllegalArgumentException
(
"Invalid kind "
+
kind
);
return
getFileForInput
(
location
,
externalizeFileName
(
className
,
kind
));
return
getFileForInput
(
location
,
RelativeFile
.
forClass
(
className
,
kind
));
}
public
FileObject
getFileForInput
(
Location
location
,
...
...
@@ -890,35 +869,32 @@ public class JavacFileManager implements StandardJavaFileManager {
nullCheck
(
packageName
);
if
(!
isRelativeUri
(
URI
.
create
(
relativeName
)))
// FIXME 6419701
throw
new
IllegalArgumentException
(
"Invalid relative name: "
+
relativeName
);
String
name
=
packageName
.
length
()
==
0
?
relativeName
:
new
File
(
externalizeFileName
(
packageName
),
relativeName
).
getPath
(
);
RelativeFile
name
=
packageName
.
length
()
==
0
?
new
RelativeFile
(
relativeName
)
:
new
RelativeFile
(
RelativeDirectory
.
forPackage
(
packageName
),
relativeName
);
return
getFileForInput
(
location
,
name
);
}
private
JavaFileObject
getFileForInput
(
Location
location
,
String
name
)
throws
IOException
{
private
JavaFileObject
getFileForInput
(
Location
location
,
RelativeFile
name
)
throws
IOException
{
Iterable
<?
extends
File
>
path
=
getLocation
(
location
);
if
(
path
==
null
)
return
null
;
for
(
File
dir:
path
)
{
if
(
dir
.
isDirectory
())
{
File
f
=
n
ew
File
(
dir
,
name
.
replace
(
'/'
,
File
.
separatorChar
)
);
File
f
=
n
ame
.
getFile
(
dir
);
if
(
f
.
exists
())
return
new
RegularFileObject
(
this
,
f
);
}
else
{
Archive
a
=
openArchive
(
dir
);
if
(
a
.
contains
(
name
))
{
int
i
=
name
.
lastIndexOf
(
'/'
);
String
dirname
=
name
.
substring
(
0
,
i
+
1
);
String
basename
=
name
.
substring
(
i
+
1
);
return
a
.
getFileObject
(
dirname
,
basename
);
return
a
.
getFileObject
(
name
.
dirname
(),
name
.
basename
());
}
}
}
return
null
;
return
null
;
}
public
JavaFileObject
getJavaFileForOutput
(
Location
location
,
...
...
@@ -933,7 +909,7 @@ public class JavacFileManager implements StandardJavaFileManager {
nullCheck
(
kind
);
if
(!
sourceOrClass
.
contains
(
kind
))
throw
new
IllegalArgumentException
(
"Invalid kind "
+
kind
);
return
getFileForOutput
(
location
,
externalizeFileName
(
className
,
kind
),
sibling
);
return
getFileForOutput
(
location
,
RelativeFile
.
forClass
(
className
,
kind
),
sibling
);
}
public
FileObject
getFileForOutput
(
Location
location
,
...
...
@@ -947,14 +923,14 @@ public class JavacFileManager implements StandardJavaFileManager {
nullCheck
(
packageName
);
if
(!
isRelativeUri
(
URI
.
create
(
relativeName
)))
// FIXME 6419701
throw
new
IllegalArgumentException
(
"relativeName is invalid"
);
String
name
=
packageName
.
length
()
==
0
?
relativeName
:
new
File
(
externalizeFileName
(
packageName
),
relativeName
).
getPath
(
);
RelativeFile
name
=
packageName
.
length
()
==
0
?
new
RelativeFile
(
relativeName
)
:
new
RelativeFile
(
RelativeDirectory
.
forPackage
(
packageName
),
relativeName
);
return
getFileForOutput
(
location
,
name
,
sibling
);
}
private
JavaFileObject
getFileForOutput
(
Location
location
,
String
fileName
,
RelativeFile
fileName
,
FileObject
sibling
)
throws
IOException
{
...
...
@@ -967,7 +943,7 @@ public class JavacFileManager implements StandardJavaFileManager {
if
(
sibling
!=
null
&&
sibling
instanceof
RegularFileObject
)
{
siblingDir
=
((
RegularFileObject
)
sibling
).
f
.
getParentFile
();
}
return
new
RegularFileObject
(
this
,
new
File
(
siblingDir
,
baseName
(
fileName
)));
return
new
RegularFileObject
(
this
,
new
File
(
siblingDir
,
fileName
.
basename
(
)));
}
}
else
if
(
location
==
SOURCE_OUTPUT
)
{
dir
=
(
getSourceOutDir
()
!=
null
?
getSourceOutDir
()
:
getClassOutDir
());
...
...
@@ -980,7 +956,7 @@ public class JavacFileManager implements StandardJavaFileManager {
}
}
File
file
=
(
dir
==
null
?
new
File
(
fileName
)
:
new
File
(
dir
,
fileName
));
File
file
=
fileName
.
getFile
(
dir
);
// null-safe
return
new
RegularFileObject
(
this
,
file
);
}
...
...
src/share/classes/com/sun/tools/javac/file/RelativePath.java
0 → 100644
浏览文件 @
98f823a6
/*
* Copyright 2008 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. Sun designates this
* particular file as subject to the "Classpath" exception as provided
* by Sun in the LICENSE file that accompanied this code.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact 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.
*/
package
com.sun.tools.javac.file
;
import
java.io.File
;
import
java.util.zip.ZipEntry
;
import
java.util.zip.ZipFile
;
import
javax.tools.JavaFileObject
;
/**
* Used to represent a platform-neutral path within a platform-specific
* container, such as a directory or zip file.
* Internally, the file separator is always '/'.
*/
public
abstract
class
RelativePath
implements
Comparable
<
RelativePath
>
{
/**
* @param p must use '/' as an internal separator
*/
protected
RelativePath
(
String
p
)
{
path
=
p
;
}
public
abstract
RelativeDirectory
dirname
();
public
abstract
String
basename
();
public
File
getFile
(
File
directory
)
{
if
(
path
.
length
()
==
0
)
return
directory
;
return
new
File
(
directory
,
path
.
replace
(
'/'
,
File
.
separatorChar
));
}
public
int
compareTo
(
RelativePath
other
)
{
return
path
.
compareTo
(
other
.
path
);
}
@Override
public
boolean
equals
(
Object
other
)
{
if
(!(
other
instanceof
RelativePath
))
return
false
;
return
path
.
equals
(((
RelativePath
)
other
).
path
);
}
@Override
public
int
hashCode
()
{
return
path
.
hashCode
();
}
@Override
public
String
toString
()
{
return
"RelPath["
+
path
+
"]"
;
}
public
String
getPath
()
{
return
path
;
}
protected
final
String
path
;
/**
* Used to represent a platform-neutral subdirectory within a platform-specific
* container, such as a directory or zip file.
* Internally, the file separator is always '/', and if the path is not empty,
* it always ends in a '/' as well.
*/
public
static
class
RelativeDirectory
extends
RelativePath
{
static
RelativeDirectory
forPackage
(
CharSequence
packageName
)
{
return
new
RelativeDirectory
(
packageName
.
toString
().
replace
(
'.'
,
'/'
));
}
/**
* @param p must use '/' as an internal separator
*/
public
RelativeDirectory
(
String
p
)
{
super
(
p
.
length
()
==
0
||
p
.
endsWith
(
"/"
)
?
p
:
p
+
"/"
);
}
/**
* @param p must use '/' as an internal separator
*/
public
RelativeDirectory
(
RelativeDirectory
d
,
String
p
)
{
this
(
d
.
path
+
p
);
}
@Override
public
RelativeDirectory
dirname
()
{
int
l
=
path
.
length
();
if
(
l
==
0
)
return
this
;
int
sep
=
path
.
lastIndexOf
(
'/'
,
l
-
2
);
return
new
RelativeDirectory
(
path
.
substring
(
0
,
sep
+
1
));
}
@Override
public
String
basename
()
{
int
l
=
path
.
length
();
if
(
l
==
0
)
return
path
;
int
sep
=
path
.
lastIndexOf
(
'/'
,
l
-
2
);
return
path
.
substring
(
sep
+
1
,
l
-
1
);
}
/**
* Return true if this subdirectory "contains" the other path.
* A subdirectory path does not contain itself.
**/
boolean
contains
(
RelativePath
other
)
{
return
other
.
path
.
length
()
>
path
.
length
()
&&
other
.
path
.
startsWith
(
path
);
}
@Override
public
String
toString
()
{
return
"RelativeDirectory["
+
path
+
"]"
;
}
}
/**
* Used to represent a platform-neutral file within a platform-specific
* container, such as a directory or zip file.
* Internally, the file separator is always '/'. It never ends in '/'.
*/
public
static
class
RelativeFile
extends
RelativePath
{
static
RelativeFile
forClass
(
CharSequence
className
,
JavaFileObject
.
Kind
kind
)
{
return
new
RelativeFile
(
className
.
toString
().
replace
(
'.'
,
'/'
)
+
kind
.
extension
);
}
public
RelativeFile
(
String
p
)
{
super
(
p
);
if
(
p
.
endsWith
(
"/"
))
throw
new
IllegalArgumentException
(
p
);
}
/**
* @param p must use '/' as an internal separator
*/
public
RelativeFile
(
RelativeDirectory
d
,
String
p
)
{
this
(
d
.
path
+
p
);
}
RelativeFile
(
RelativeDirectory
d
,
RelativePath
p
)
{
this
(
d
,
p
.
path
);
}
@Override
public
RelativeDirectory
dirname
()
{
int
sep
=
path
.
lastIndexOf
(
'/'
);
return
new
RelativeDirectory
(
path
.
substring
(
0
,
sep
+
1
));
}
@Override
public
String
basename
()
{
int
sep
=
path
.
lastIndexOf
(
'/'
);
return
path
.
substring
(
sep
+
1
);
}
ZipEntry
getZipEntry
(
ZipFile
zip
)
{
return
zip
.
getEntry
(
path
);
}
@Override
public
String
toString
()
{
return
"RelativeFile["
+
path
+
"]"
;
}
}
}
src/share/classes/com/sun/tools/javac/file/SymbolArchive.java
浏览文件 @
98f823a6
...
...
@@ -25,47 +25,75 @@
package
com.sun.tools.javac.file
;
import
com.sun.tools.javac.util.List
;
import
java.io.File
;
import
java.io.IOException
;
import
java.util.zip.ZipEntry
;
import
java.util.zip.ZipFile
;
import
javax.tools.JavaFileObject
;
import
com.sun.tools.javac.file.RelativePath.RelativeDirectory
;
import
com.sun.tools.javac.file.RelativePath.RelativeFile
;
import
com.sun.tools.javac.util.List
;
public
class
SymbolArchive
extends
ZipArchive
{
final
File
origFile
;
final
String
prefix
;
final
RelativeDirectory
prefix
;
public
SymbolArchive
(
JavacFileManager
fileManager
,
File
orig
,
ZipFile
zdir
,
String
prefix
)
throws
IOException
{
super
(
fileManager
,
zdir
);
public
SymbolArchive
(
JavacFileManager
fileManager
,
File
orig
,
ZipFile
zdir
,
RelativeDirectory
prefix
)
throws
IOException
{
super
(
fileManager
,
zdir
,
false
);
this
.
origFile
=
orig
;
this
.
prefix
=
prefix
;
initMap
();
}
@Override
void
addZipEntry
(
ZipEntry
entry
)
{
String
name
=
entry
.
getName
();
if
(!
name
.
startsWith
(
prefix
))
{
if
(!
name
.
startsWith
(
prefix
.
path
))
{
return
;
}
name
=
name
.
substring
(
prefix
.
length
());
name
=
name
.
substring
(
prefix
.
path
.
length
());
int
i
=
name
.
lastIndexOf
(
'/'
);
String
dirname
=
name
.
substring
(
0
,
i
+
1
);
RelativeDirectory
dirname
=
new
RelativeDirectory
(
name
.
substring
(
0
,
i
+
1
)
);
String
basename
=
name
.
substring
(
i
+
1
);
if
(
basename
.
length
()
==
0
)
{
return
;
}
List
<
String
>
list
=
map
.
get
(
dirname
);
if
(
list
==
null
)
{
if
(
list
==
null
)
list
=
List
.
nil
();
}
list
=
list
.
prepend
(
basename
);
map
.
put
(
dirname
,
list
);
}
@Override
public
JavaFileObject
getFileObject
(
String
subdirectory
,
String
file
)
{
return
super
.
getFileObject
(
prefix
+
subdirectory
,
file
);
public
JavaFileObject
getFileObject
(
RelativeDirectory
subdirectory
,
String
file
)
{
RelativeDirectory
prefix_subdir
=
new
RelativeDirectory
(
prefix
,
subdirectory
.
path
);
ZipEntry
ze
=
new
RelativeFile
(
prefix_subdir
,
file
).
getZipEntry
(
zdir
);
return
new
SymbolFileObject
(
this
,
file
,
ze
);
}
public
String
toString
()
{
return
"SymbolArchive["
+
zdir
.
getName
()
+
"]"
;
}
/**
* A subclass of JavaFileObject representing zip entries in a symbol file.
*/
public
static
class
SymbolFileObject
extends
ZipFileObject
{
protected
SymbolFileObject
(
SymbolArchive
zarch
,
String
name
,
ZipEntry
entry
)
{
super
(
zarch
,
name
,
entry
);
}
@Override
protected
String
inferBinaryName
(
Iterable
<?
extends
File
>
path
)
{
String
entryName
=
getZipEntryName
();
String
prefix
=
((
SymbolArchive
)
zarch
).
prefix
.
path
;
if
(
entryName
.
startsWith
(
prefix
))
entryName
=
entryName
.
substring
(
prefix
.
length
());
return
removeExtension
(
entryName
).
replace
(
'/'
,
'.'
);
}
}
}
src/share/classes/com/sun/tools/javac/file/ZipArchive.java
浏览文件 @
98f823a6
...
...
@@ -25,32 +25,44 @@
package
com.sun.tools.javac.file
;
import
java.io.File
;
import
java.io.IOException
;
import
java.io.InputStream
;
import
java.io.OutputStream
;
import
java.io.Writer
;
import
java.net.URI
;
import
java.nio.ByteBuffer
;
import
java.nio.CharBuffer
;
import
java.nio.charset.CharsetDecoder
;
import
java.util.Enumeration
;
import
java.util.HashMap
;
import
java.util.Map
;
import
java.util.Set
;
import
java.util.zip.ZipEntry
;
import
java.util.zip.ZipFile
;
import
javax.tools.JavaFileObject
;
import
com.sun.tools.javac.file.JavacFileManager.Archive
;
import
com.sun.tools.javac.file.RelativePath.RelativeDirectory
;
import
com.sun.tools.javac.file.RelativePath.RelativeFile
;
import
com.sun.tools.javac.util.List
;
import
java.io.File
;
import
java.io.InputStream
;
import
java.io.OutputStream
;
import
java.io.Writer
;
import
java.net.URI
;
import
java.nio.ByteBuffer
;
import
java.nio.CharBuffer
;
import
java.nio.charset.CharsetDecoder
;
public
class
ZipArchive
implements
Archive
{
public
ZipArchive
(
JavacFileManager
fm
,
ZipFile
zdir
)
throws
IOException
{
this
(
fm
,
zdir
,
true
);
}
protected
ZipArchive
(
JavacFileManager
fm
,
ZipFile
zdir
,
boolean
initMap
)
throws
IOException
{
this
.
fileManager
=
fm
;
this
.
zdir
=
zdir
;
this
.
map
=
new
HashMap
<
String
,
List
<
String
>>();
this
.
map
=
new
HashMap
<
RelativeDirectory
,
List
<
String
>>();
if
(
initMap
)
initMap
();
}
protected
void
initMap
()
throws
IOException
{
for
(
Enumeration
<?
extends
ZipEntry
>
e
=
zdir
.
entries
();
e
.
hasMoreElements
();
)
{
ZipEntry
entry
;
try
{
...
...
@@ -67,7 +79,7 @@ public class ZipArchive implements Archive {
void
addZipEntry
(
ZipEntry
entry
)
{
String
name
=
entry
.
getName
();
int
i
=
name
.
lastIndexOf
(
'/'
);
String
dirname
=
name
.
substring
(
0
,
i
+
1
);
RelativeDirectory
dirname
=
new
RelativeDirectory
(
name
.
substring
(
0
,
i
+
1
)
);
String
basename
=
name
.
substring
(
i
+
1
);
if
(
basename
.
length
()
==
0
)
return
;
...
...
@@ -78,26 +90,25 @@ public class ZipArchive implements Archive {
map
.
put
(
dirname
,
list
);
}
public
boolean
contains
(
String
name
)
{
int
i
=
name
.
lastIndexOf
(
'/'
);
String
dirname
=
name
.
substring
(
0
,
i
+
1
);
String
basename
=
name
.
substring
(
i
+
1
);
public
boolean
contains
(
RelativePath
name
)
{
RelativeDirectory
dirname
=
name
.
dirname
();
String
basename
=
name
.
basename
();
if
(
basename
.
length
()
==
0
)
return
false
;
List
<
String
>
list
=
map
.
get
(
dirname
);
return
(
list
!=
null
&&
list
.
contains
(
basename
));
}
public
List
<
String
>
getFiles
(
String
subdirectory
)
{
public
List
<
String
>
getFiles
(
RelativeDirectory
subdirectory
)
{
return
map
.
get
(
subdirectory
);
}
public
JavaFileObject
getFileObject
(
String
subdirectory
,
String
file
)
{
ZipEntry
ze
=
zdir
.
getEntry
(
subdirectory
+
file
);
public
JavaFileObject
getFileObject
(
RelativeDirectory
subdirectory
,
String
file
)
{
ZipEntry
ze
=
new
RelativeFile
(
subdirectory
,
file
).
getZipEntry
(
zdir
);
return
new
ZipFileObject
(
this
,
file
,
ze
);
}
public
Set
<
String
>
getSubdirectories
()
{
public
Set
<
RelativeDirectory
>
getSubdirectories
()
{
return
map
.
keySet
();
}
...
...
@@ -105,8 +116,12 @@ public class ZipArchive implements Archive {
zdir
.
close
();
}
public
String
toString
()
{
return
"ZipArchive["
+
zdir
.
getName
()
+
"]"
;
}
protected
JavacFileManager
fileManager
;
protected
final
Map
<
String
,
List
<
String
>>
map
;
protected
final
Map
<
RelativeDirectory
,
List
<
String
>>
map
;
protected
final
ZipFile
zdir
;
/**
...
...
@@ -118,7 +133,7 @@ public class ZipArchive implements Archive {
ZipArchive
zarch
;
ZipEntry
entry
;
p
ublic
ZipFileObject
(
ZipArchive
zarch
,
String
name
,
ZipEntry
entry
)
{
p
rotected
ZipFileObject
(
ZipArchive
zarch
,
String
name
,
ZipEntry
entry
)
{
super
(
zarch
.
fileManager
);
this
.
zarch
=
zarch
;
this
.
name
=
name
;
...
...
@@ -222,11 +237,6 @@ public class ZipArchive implements Archive {
@Override
protected
String
inferBinaryName
(
Iterable
<?
extends
File
>
path
)
{
String
entryName
=
getZipEntryName
();
if
(
zarch
instanceof
SymbolArchive
)
{
String
prefix
=
((
SymbolArchive
)
zarch
).
prefix
;
if
(
entryName
.
startsWith
(
prefix
))
entryName
=
entryName
.
substring
(
prefix
.
length
());
}
return
removeExtension
(
entryName
).
replace
(
'/'
,
'.'
);
}
}
...
...
src/share/classes/com/sun/tools/javac/file/ZipFileIndex.java
浏览文件 @
98f823a6
此差异已折叠。
点击以展开。
src/share/classes/com/sun/tools/javac/file/ZipFileIndexArchive.java
浏览文件 @
98f823a6
...
...
@@ -29,11 +29,8 @@ import java.io.IOException;
import
java.util.Set
;
import
javax.tools.JavaFileObject
;
import
com.sun.tools.javac.file.JavacFileManager.Archive
;
import
com.sun.tools.javac.util.List
;
import
java.io.ByteArrayInputStream
;
import
java.io.File
;
import
java.io.FileNotFoundException
;
import
java.io.InputStream
;
import
java.io.OutputStream
;
import
java.io.Writer
;
...
...
@@ -42,6 +39,11 @@ import java.nio.ByteBuffer;
import
java.nio.CharBuffer
;
import
java.nio.charset.CharsetDecoder
;
import
com.sun.tools.javac.file.JavacFileManager.Archive
;
import
com.sun.tools.javac.file.RelativePath.RelativeDirectory
;
import
com.sun.tools.javac.file.RelativePath.RelativeFile
;
import
com.sun.tools.javac.util.List
;
public
class
ZipFileIndexArchive
implements
Archive
{
private
final
ZipFileIndex
zfIndex
;
...
...
@@ -53,22 +55,22 @@ public class ZipFileIndexArchive implements Archive {
this
.
zfIndex
=
zdir
;
}
public
boolean
contains
(
String
name
)
{
public
boolean
contains
(
RelativePath
name
)
{
return
zfIndex
.
contains
(
name
);
}
public
List
<
String
>
getFiles
(
String
subdirectory
)
{
return
zfIndex
.
getFiles
(
(
subdirectory
.
endsWith
(
"/"
)
||
subdirectory
.
endsWith
(
"\\"
))
?
subdirectory
.
substring
(
0
,
subdirectory
.
length
()
-
1
)
:
subdirectory
);
public
List
<
String
>
getFiles
(
RelativeDirectory
subdirectory
)
{
return
zfIndex
.
getFiles
(
subdirectory
);
}
public
JavaFileObject
getFileObject
(
String
subdirectory
,
String
file
)
{
String
fullZipFileName
=
subdirectory
+
file
;
public
JavaFileObject
getFileObject
(
RelativeDirectory
subdirectory
,
String
file
)
{
RelativeFile
fullZipFileName
=
new
RelativeFile
(
subdirectory
,
file
)
;
ZipFileIndex
.
Entry
entry
=
zfIndex
.
getZipIndexEntry
(
fullZipFileName
);
JavaFileObject
ret
=
new
ZipFileIndexFileObject
(
fileManager
,
zfIndex
,
entry
,
zfIndex
.
getZipFile
().
getPath
());
return
ret
;
}
public
Set
<
String
>
getSubdirectories
()
{
public
Set
<
RelativeDirectory
>
getSubdirectories
()
{
return
zfIndex
.
getAllDirectories
();
}
...
...
@@ -76,6 +78,10 @@ public class ZipFileIndexArchive implements Archive {
zfIndex
.
close
();
}
public
String
toString
()
{
return
"ZipFileIndexArchive["
+
zfIndex
+
"]"
;
}
/**
* A subclass of JavaFileObject representing zip entries using the com.sun.tools.javac.file.ZipFileIndex implementation.
*/
...
...
@@ -181,18 +187,11 @@ public class ZipFileIndexArchive implements Archive {
public
URI
toUri
()
{
String
zipName
=
new
File
(
getZipName
()).
toURI
().
normalize
().
getPath
();
String
entryName
=
getZipEntryName
();
if
(
File
.
separatorChar
!=
'/'
)
{
entryName
=
entryName
.
replace
(
File
.
separatorChar
,
'/'
);
}
return
URI
.
create
(
"jar:"
+
zipName
+
"!"
+
entryName
);
}
private
byte
[]
read
()
throws
IOException
{
if
(
entry
==
null
)
{
entry
=
zfIndex
.
getZipIndexEntry
(
name
);
if
(
entry
==
null
)
throw
new
FileNotFoundException
();
}
assert
entry
!=
null
;
// see constructor
return
zfIndex
.
read
(
entry
);
}
...
...
@@ -222,11 +221,11 @@ public class ZipFileIndexArchive implements Archive {
protected
String
inferBinaryName
(
Iterable
<?
extends
File
>
path
)
{
String
entryName
=
getZipEntryName
();
if
(
zfIndex
.
symbolFilePrefix
!=
null
)
{
String
prefix
=
zfIndex
.
symbolFilePrefix
;
String
prefix
=
zfIndex
.
symbolFilePrefix
.
path
;
if
(
entryName
.
startsWith
(
prefix
))
entryName
=
entryName
.
substring
(
prefix
.
length
());
}
return
removeExtension
(
entryName
).
replace
(
File
.
separatorChar
,
'.'
);
return
removeExtension
(
entryName
).
replace
(
'/'
,
'.'
);
}
}
...
...
src/share/classes/com/sun/tools/javadoc/DocletInvoker.java
浏览文件 @
98f823a6
...
...
@@ -82,6 +82,7 @@ public class DocletInvoker {
cpString
=
appendPath
(
System
.
getProperty
(
"java.class.path"
),
cpString
);
cpString
=
appendPath
(
docletPath
,
cpString
);
URL
[]
urls
=
pathToURLs
(
cpString
);
System
.
err
.
println
(
"DocletInvoker urls="
+
urls
);
appClassLoader
=
new
URLClassLoader
(
urls
);
// attempt to find doclet
...
...
src/share/classes/javax/tools/StandardLocation.java
浏览文件 @
98f823a6
...
...
@@ -27,8 +27,6 @@ package javax.tools;
import
javax.tools.JavaFileManager.Location
;
import
java.io.File
;
import
java.util.*
;
import
java.util.concurrent.*
;
/**
...
...
test/tools/javac/6508981/TestInferBinaryName.java
0 → 100644
浏览文件 @
98f823a6
/*
* Copyright 2008 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 6508981
* @summary cleanup file separator handling in JavacFileManager
* (This test is specifically to test the new impl of inferBinaryName)
* @build p.A
* @run main TestInferBinaryName
*/
import
java.io.*
;
import
java.util.*
;
import
javax.tools.*
;
import
com.sun.tools.javac.file.JavacFileManager
;
import
com.sun.tools.javac.util.Context
;
import
com.sun.tools.javac.util.Options
;
import
static
javax
.
tools
.
JavaFileObject
.
Kind
.*;
import
static
javax
.
tools
.
StandardLocation
.*;
/**
* Verify the various implementations of inferBinaryName, but configuring
* different instances of a file manager, getting a file object, and checking
* the impl of inferBinaryName for that file object.
*/
public
class
TestInferBinaryName
{
static
final
boolean
IGNORE_SYMBOL_FILE
=
false
;
static
final
boolean
USE_SYMBOL_FILE
=
true
;
static
final
boolean
DONT_USE_ZIP_FILE_INDEX
=
false
;
static
final
boolean
USE_ZIP_FILE_INDEX
=
true
;
public
static
void
main
(
String
...
args
)
throws
Exception
{
new
TestInferBinaryName
().
run
();
}
void
run
()
throws
Exception
{
//System.err.println(System.getProperties());
testDirectory
();
testSymbolArchive
();
testZipArchive
();
testZipFileIndexArchive
();
testZipFileIndexArchive2
();
if
(
errors
>
0
)
throw
new
Exception
(
errors
+
" error found"
);
}
void
testDirectory
()
throws
IOException
{
String
testClassName
=
"p.A"
;
JavaFileManager
fm
=
getFileManager
(
"test.classes"
,
USE_SYMBOL_FILE
,
USE_ZIP_FILE_INDEX
);
test
(
"testDirectory"
,
fm
,
testClassName
,
"com.sun.tools.javac.file.RegularFileObject"
);
}
void
testSymbolArchive
()
throws
IOException
{
String
testClassName
=
"java.lang.String"
;
JavaFileManager
fm
=
getFileManager
(
"sun.boot.class.path"
,
USE_SYMBOL_FILE
,
DONT_USE_ZIP_FILE_INDEX
);
test
(
"testSymbolArchive"
,
fm
,
testClassName
,
"com.sun.tools.javac.file.SymbolArchive$SymbolFileObject"
);
}
void
testZipArchive
()
throws
IOException
{
String
testClassName
=
"java.lang.String"
;
JavaFileManager
fm
=
getFileManager
(
"sun.boot.class.path"
,
IGNORE_SYMBOL_FILE
,
DONT_USE_ZIP_FILE_INDEX
);
test
(
"testZipArchive"
,
fm
,
testClassName
,
"com.sun.tools.javac.file.ZipArchive$ZipFileObject"
);
}
void
testZipFileIndexArchive
()
throws
IOException
{
String
testClassName
=
"java.lang.String"
;
JavaFileManager
fm
=
getFileManager
(
"sun.boot.class.path"
,
USE_SYMBOL_FILE
,
USE_ZIP_FILE_INDEX
);
test
(
"testZipFileIndexArchive"
,
fm
,
testClassName
,
"com.sun.tools.javac.file.ZipFileIndexArchive$ZipFileIndexFileObject"
);
}
void
testZipFileIndexArchive2
()
throws
IOException
{
String
testClassName
=
"java.lang.String"
;
JavaFileManager
fm
=
getFileManager
(
"sun.boot.class.path"
,
IGNORE_SYMBOL_FILE
,
USE_ZIP_FILE_INDEX
);
test
(
"testZipFileIndexArchive2"
,
fm
,
testClassName
,
"com.sun.tools.javac.file.ZipFileIndexArchive$ZipFileIndexFileObject"
);
}
/**
* @param testName for debugging
* @param fm suitably configured file manager
* @param testClassName the classname to test
* @param implClassName the expected classname of the JavaFileObject impl,
* used for checking that we are checking the expected impl of
* inferBinaryName
*/
void
test
(
String
testName
,
JavaFileManager
fm
,
String
testClassName
,
String
implClassName
)
throws
IOException
{
JavaFileObject
fo
=
fm
.
getJavaFileForInput
(
CLASS_PATH
,
testClassName
,
CLASS
);
if
(
fo
==
null
)
{
System
.
err
.
println
(
"Can't find "
+
testClassName
);
errors
++;
return
;
}
String
cn
=
fo
.
getClass
().
getName
();
String
bn
=
fm
.
inferBinaryName
(
CLASS_PATH
,
fo
);
System
.
err
.
println
(
testName
+
" "
+
cn
+
" "
+
bn
);
check
(
cn
,
implClassName
);
check
(
bn
,
testClassName
);
System
.
err
.
println
(
"OK"
);
}
JavaFileManager
getFileManager
(
String
classpathProperty
,
boolean
symFileKind
,
boolean
zipFileIndexKind
)
throws
IOException
{
Context
ctx
=
new
Context
();
// uugh, ugly back door, should be cleaned up, someday
if
(
zipFileIndexKind
==
USE_ZIP_FILE_INDEX
)
System
.
clearProperty
(
"useJavaUtilZip"
);
else
System
.
setProperty
(
"useJavaUtilZip"
,
"true"
);
Options
options
=
Options
.
instance
(
ctx
);
if
(
symFileKind
==
IGNORE_SYMBOL_FILE
)
options
.
put
(
"ignore.symbol.file"
,
"true"
);
JavacFileManager
fm
=
new
JavacFileManager
(
ctx
,
false
,
null
);
List
<
File
>
path
=
getPath
(
System
.
getProperty
(
classpathProperty
));
fm
.
setLocation
(
CLASS_PATH
,
path
);
return
fm
;
}
List
<
File
>
getPath
(
String
s
)
{
List
<
File
>
path
=
new
ArrayList
<
File
>();
for
(
String
f:
s
.
split
(
File
.
pathSeparator
))
{
if
(
f
.
length
()
>
0
)
path
.
add
(
new
File
(
f
));
}
//System.err.println("path: " + path);
return
path
;
}
void
check
(
String
found
,
String
expect
)
{
if
(!
found
.
equals
(
expect
))
{
System
.
err
.
println
(
"Expected: "
+
expect
);
System
.
err
.
println
(
" Found: "
+
found
);
errors
++;
}
}
private
int
errors
;
}
class
A
{
}
test/tools/javac/6508981/p/A.java
0 → 100644
浏览文件 @
98f823a6
/*
* Copyright 2008 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.
*/
package
p
;
class
A
{
}
test/tools/javac/T6725036.java
浏览文件 @
98f823a6
...
...
@@ -35,6 +35,7 @@ import java.util.jar.JarFile;
import
javax.tools.JavaFileObject
;
import
com.sun.tools.javac.file.JavacFileManager
;
import
com.sun.tools.javac.file.RelativePath.RelativeFile
;
import
com.sun.tools.javac.file.ZipFileIndex
;
import
com.sun.tools.javac.file.ZipFileIndexArchive
;
import
com.sun.tools.javac.util.Context
;
...
...
@@ -45,7 +46,7 @@ public class T6725036 {
}
void
run
()
throws
Exception
{
String
TEST_ENTRY_NAME
=
"java/lang/String.class"
;
RelativeFile
TEST_ENTRY_NAME
=
new
RelativeFile
(
"java/lang/String.class"
)
;
File
f
=
new
File
(
System
.
getProperty
(
"java.home"
));
if
(!
f
.
getName
().
equals
(
"jre"
))
...
...
@@ -53,22 +54,21 @@ public class T6725036 {
File
rt_jar
=
new
File
(
new
File
(
f
,
"lib"
),
"rt.jar"
);
JarFile
j
=
new
JarFile
(
rt_jar
);
JarEntry
je
=
j
.
getJarEntry
(
TEST_ENTRY_NAME
);
JarEntry
je
=
j
.
getJarEntry
(
TEST_ENTRY_NAME
.
getPath
()
);
long
jarEntryTime
=
je
.
getTime
();
ZipFileIndex
zfi
=
ZipFileIndex
.
getZipFileIndex
(
rt_jar
,
null
,
false
,
null
,
false
);
long
zfiTime
=
zfi
.
getLastModified
(
TEST_ENTRY_NAME
);
check
(
je
,
jarEntryTime
,
zfi
+
":"
+
TEST_ENTRY_NAME
,
zfiTime
);
check
(
je
,
jarEntryTime
,
zfi
+
":"
+
TEST_ENTRY_NAME
.
getPath
()
,
zfiTime
);
Context
context
=
new
Context
();
JavacFileManager
fm
=
new
JavacFileManager
(
context
,
false
,
null
);
ZipFileIndexArchive
zfia
=
new
ZipFileIndexArchive
(
fm
,
zfi
);
int
sep
=
TEST_ENTRY_NAME
.
lastIndexOf
(
"/"
);
JavaFileObject
jfo
=
zfia
.
getFileObject
(
TEST_ENTRY_NAME
.
substring
(
0
,
sep
+
1
),
TEST_ENTRY_NAME
.
substring
(
sep
+
1
));
zfia
.
getFileObject
(
TEST_ENTRY_NAME
.
dirname
(
),
TEST_ENTRY_NAME
.
basename
(
));
long
jfoTime
=
jfo
.
getLastModified
();
check
(
je
,
jarEntryTime
,
jfo
,
jfoTime
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录