Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_langtools
提交
63062e59
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看板
提交
63062e59
编写于
8月 26, 2010
作者:
J
jjg
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
6980017: javap -XDdetail:source behaves badly if source not available.
Reviewed-by: ksrini
上级
2f52268b
变更
3
显示空白变更内容
内联
并排
Showing
3 changed file
with
85 addition
and
1 deletion
+85
-1
src/share/classes/com/sun/tools/javap/CodeWriter.java
src/share/classes/com/sun/tools/javap/CodeWriter.java
+4
-1
src/share/classes/com/sun/tools/javap/SourceWriter.java
src/share/classes/com/sun/tools/javap/SourceWriter.java
+3
-0
test/tools/javap/T6980017.java
test/tools/javap/T6980017.java
+78
-0
未找到文件。
src/share/classes/com/sun/tools/javap/CodeWriter.java
浏览文件 @
63062e59
...
@@ -239,7 +239,10 @@ class CodeWriter extends BasicWriter {
...
@@ -239,7 +239,10 @@ class CodeWriter extends BasicWriter {
new
ArrayList
<
InstructionDetailWriter
>();
new
ArrayList
<
InstructionDetailWriter
>();
if
(
options
.
details
.
contains
(
InstructionDetailWriter
.
Kind
.
SOURCE
))
{
if
(
options
.
details
.
contains
(
InstructionDetailWriter
.
Kind
.
SOURCE
))
{
sourceWriter
.
reset
(
classWriter
.
getClassFile
(),
attr
);
sourceWriter
.
reset
(
classWriter
.
getClassFile
(),
attr
);
if
(
sourceWriter
.
hasSource
())
detailWriters
.
add
(
sourceWriter
);
detailWriters
.
add
(
sourceWriter
);
else
println
(
"(Source code not available)"
);
}
}
if
(
options
.
details
.
contains
(
InstructionDetailWriter
.
Kind
.
LOCAL_VARS
))
{
if
(
options
.
details
.
contains
(
InstructionDetailWriter
.
Kind
.
LOCAL_VARS
))
{
...
...
src/share/classes/com/sun/tools/javap/SourceWriter.java
浏览文件 @
63062e59
...
@@ -99,7 +99,10 @@ public class SourceWriter extends InstructionDetailWriter {
...
@@ -99,7 +99,10 @@ public class SourceWriter extends InstructionDetailWriter {
}
}
}
}
}
}
}
public
boolean
hasSource
()
{
return
(
sourceLines
.
length
>
0
);
}
}
private
void
setLineMap
(
Code_attribute
attr
)
{
private
void
setLineMap
(
Code_attribute
attr
)
{
...
...
test/tools/javap/T6980017.java
0 → 100644
浏览文件 @
63062e59
/*
* Copyright (c) 2010, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/*
* @test
* @bug 6980017
* @summary javap -XDdetail:source behaves badly if source not available.
*/
import
java.io.*
;
public
class
T6980017
{
public
static
void
main
(
String
...
args
)
throws
Exception
{
new
T6980017
().
run
();
}
void
run
()
throws
Exception
{
String
[]
args
=
{
"-v"
,
"-XDdetails:source"
,
"java.lang.String"
};
StringWriter
sw
=
new
StringWriter
();
PrintWriter
pw
=
new
PrintWriter
(
sw
);
int
rc
=
com
.
sun
.
tools
.
javap
.
Main
.
run
(
args
,
pw
);
pw
.
close
();
if
(
rc
!=
0
)
error
(
"Unexpected exit code: "
+
rc
);
boolean
foundBlankSourceLine
=
false
;
boolean
foundNoSourceLine
=
false
;
for
(
String
line:
sw
.
toString
().
split
(
"[\r\n]+"
))
{
System
.
err
.
println
(
line
);
if
(
line
.
contains
(
"Source code not available"
))
foundNoSourceLine
=
true
;
if
(
line
.
matches
(
"\\s*\\( *[0-9]+\\)\\s*"
))
foundBlankSourceLine
=
true
;
}
if
(
foundBlankSourceLine
)
error
(
"found blank source lines"
);
if
(!
foundNoSourceLine
)
error
(
"did not find \"Source code not available\" message"
);
if
(
errors
>
0
)
throw
new
Exception
(
errors
+
" errors occurred"
);
}
void
error
(
String
msg
)
{
System
.
err
.
println
(
msg
);
errors
++;
}
int
errors
;
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录