Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_langtools
提交
efad9d13
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看板
提交
efad9d13
编写于
2月 18, 2011
作者:
D
darcy
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
7020047: Project Coin: generate null-check around try-with-resources close call
Reviewed-by: jjg
上级
0d2cd21f
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
130 addition
and
20 deletion
+130
-20
src/share/classes/com/sun/tools/javac/comp/Lower.java
src/share/classes/com/sun/tools/javac/comp/Lower.java
+58
-20
test/tools/javac/TryWithResources/TwrNullTests.java
test/tools/javac/TryWithResources/TwrNullTests.java
+72
-0
未找到文件。
src/share/classes/com/sun/tools/javac/comp/Lower.java
浏览文件 @
efad9d13
...
...
@@ -1425,25 +1425,55 @@ public class Lower extends TreeTranslator {
}
}
/** Optionally replace a try statement with an automatic resource
* management (ARM) block.
/**
* Optionally replace a try statement with the desugaring of a
* try-with-resources statement. The canonical desugaring of
*
* try ResourceSpecification
* Block
*
* is
*
* {
* final VariableModifiers_minus_final R #resource = Expression;
* Throwable #primaryException = null;
*
* try ResourceSpecificationtail
* Block
* catch (Throwable #t) {
* #primaryException = t;
* throw #t;
* } finally {
* if (#resource != null) {
* if (#primaryException != null) {
* try {
* #resource.close();
* } catch(Throwable #suppressedException) {
* #primaryException.addSuppressed(#suppressedException);
* }
* } else {
* #resource.close();
* }
* }
* }
*
* @param tree The try statement to inspect.
* @return
An ARM block, or the original try block if there are no
*
resources to manage.
* @return
A a desugared try-with-resources tree, or the original
*
try block if there are no
resources to manage.
*/
JCTree
make
Arm
Try
(
JCTry
tree
)
{
JCTree
make
Twr
Try
(
JCTry
tree
)
{
make_at
(
tree
.
pos
());
twrVars
=
twrVars
.
dup
();
JCBlock
armBlock
=
makeArm
Block
(
tree
.
resources
,
tree
.
body
,
0
);
JCBlock
twrBlock
=
makeTwr
Block
(
tree
.
resources
,
tree
.
body
,
0
);
if
(
tree
.
catchers
.
isEmpty
()
&&
tree
.
finalizer
==
null
)
result
=
translate
(
arm
Block
);
result
=
translate
(
twr
Block
);
else
result
=
translate
(
make
.
Try
(
arm
Block
,
tree
.
catchers
,
tree
.
finalizer
));
result
=
translate
(
make
.
Try
(
twr
Block
,
tree
.
catchers
,
tree
.
finalizer
));
twrVars
=
twrVars
.
leave
();
return
result
;
}
private
JCBlock
make
Arm
Block
(
List
<
JCTree
>
resources
,
JCBlock
block
,
int
depth
)
{
private
JCBlock
make
Twr
Block
(
List
<
JCTree
>
resources
,
JCBlock
block
,
int
depth
)
{
if
(
resources
.
isEmpty
())
return
block
;
...
...
@@ -1497,16 +1527,16 @@ public class Lower extends TreeTranslator {
int
oldPos
=
make
.
pos
;
make
.
at
(
TreeInfo
.
endPos
(
block
));
JCBlock
finallyClause
=
make
Arm
FinallyClause
(
primaryException
,
expr
);
JCBlock
finallyClause
=
make
Twr
FinallyClause
(
primaryException
,
expr
);
make
.
at
(
oldPos
);
JCTry
outerTry
=
make
.
Try
(
make
Arm
Block
(
resources
.
tail
,
block
,
depth
+
1
),
JCTry
outerTry
=
make
.
Try
(
make
Twr
Block
(
resources
.
tail
,
block
,
depth
+
1
),
List
.<
JCCatch
>
of
(
catchClause
),
finallyClause
);
stats
.
add
(
outerTry
);
return
make
.
Block
(
0L
,
stats
.
toList
());
}
private
JCBlock
make
Arm
FinallyClause
(
Symbol
primaryException
,
JCExpression
resource
)
{
private
JCBlock
make
Twr
FinallyClause
(
Symbol
primaryException
,
JCExpression
resource
)
{
// primaryException.addSuppressed(catchException);
VarSymbol
catchException
=
new
VarSymbol
(
0
,
make
.
paramName
(
2
),
...
...
@@ -1525,22 +1555,30 @@ public class Lower extends TreeTranslator {
List
<
JCCatch
>
catchClauses
=
List
.<
JCCatch
>
of
(
make
.
Catch
(
catchExceptionDecl
,
catchBlock
));
JCTry
tryTree
=
make
.
Try
(
tryBlock
,
catchClauses
,
null
);
// if (resource != null) resourceClose;
JCExpression
nullCheck
=
makeBinary
(
JCTree
.
NE
,
make
.
Ident
(
primaryException
),
makeNull
());
JCIf
closeIfStatement
=
make
.
If
(
nullCheck
,
// if (primaryException != null) {try...} else resourceClose;
JCIf
closeIfStatement
=
make
.
If
(
makeNonNullCheck
(
make
.
Ident
(
primaryException
)),
tryTree
,
makeResourceCloseInvocation
(
resource
));
return
make
.
Block
(
0L
,
List
.<
JCStatement
>
of
(
closeIfStatement
));
// if (#resource != null) { if (primaryException ... }
return
make
.
Block
(
0L
,
List
.<
JCStatement
>
of
(
make
.
If
(
makeNonNullCheck
(
resource
),
closeIfStatement
,
null
)));
}
private
JCStatement
makeResourceCloseInvocation
(
JCExpression
resource
)
{
// create resource.close() method invocation
JCExpression
resourceClose
=
makeCall
(
resource
,
names
.
close
,
List
.<
JCExpression
>
nil
());
JCExpression
resourceClose
=
makeCall
(
resource
,
names
.
close
,
List
.<
JCExpression
>
nil
());
return
make
.
Exec
(
resourceClose
);
}
private
JCExpression
makeNonNullCheck
(
JCExpression
expression
)
{
return
makeBinary
(
JCTree
.
NE
,
expression
,
makeNull
());
}
/** Construct a tree that represents the outer instance
* <C.this>. Never pick the current `this'.
* @param pos The source code position to be used for the tree.
...
...
@@ -3573,7 +3611,7 @@ public class Lower extends TreeTranslator {
if
(
tree
.
resources
.
isEmpty
())
{
super
.
visitTry
(
tree
);
}
else
{
result
=
make
Arm
Try
(
tree
);
result
=
make
Twr
Try
(
tree
);
}
}
...
...
test/tools/javac/TryWithResources/TwrNullTests.java
0 → 100644
浏览文件 @
efad9d13
/*
* Copyright (c) 2011, 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 7020047
* @summary Test null handling of try-with-resources statement
*/
public
class
TwrNullTests
{
/*
* Each try-with-resources statement generates two calls to the
* close method for each resource: one for when there is a primary
* exception present and the second for when a primary exception
* is absent. The null handling of both cases needs to be
* checked.
*/
public
static
void
main
(
String
...
args
)
{
testNormalCompletion
();
testNoSuppression
();
}
/*
* Verify empty try-with-resources on a null resource completes
* normally; no NPE from the generated close call.
*/
private
static
void
testNormalCompletion
()
{
try
(
AutoCloseable
resource
=
null
)
{
return
;
// Nothing to see here, move along.
}
catch
(
Exception
e
)
{
throw
new
AssertionError
(
"Should not be reached"
,
e
);
}
}
/*
* Verify that a NPE on a null resource is <em>not</em> added as a
* suppressed exception to an exception from try block.
*/
private
static
void
testNoSuppression
()
{
try
(
AutoCloseable
resource
=
null
)
{
throw
new
java
.
io
.
IOException
();
}
catch
(
java
.
io
.
IOException
ioe
)
{
Throwable
[]
suppressed
=
ioe
.
getSuppressed
();
if
(
suppressed
.
length
!=
0
)
{
throw
new
AssertionError
(
"Non-empty suppressed exceptions"
,
ioe
);
}
}
catch
(
Exception
e
)
{
throw
new
AssertionError
(
"Should not be reached"
,
e
);
}
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录