Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_langtools
提交
ef659bfa
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看板
提交
ef659bfa
编写于
5月 21, 2012
作者:
L
lana
浏览文件
操作
浏览文件
下载
差异文件
Merge
上级
f822fead
6aad28dd
变更
8
隐藏空白更改
内联
并排
Showing
8 changed file
with
232 addition
and
7 deletion
+232
-7
src/share/classes/com/sun/tools/javac/comp/Lower.java
src/share/classes/com/sun/tools/javac/comp/Lower.java
+5
-0
src/share/classes/com/sun/tools/javac/parser/JavacParser.java
...share/classes/com/sun/tools/javac/parser/JavacParser.java
+7
-2
src/share/classes/com/sun/tools/javac/processing/JavacMessager.java
...classes/com/sun/tools/javac/processing/JavacMessager.java
+4
-2
src/share/classes/com/sun/tools/javac/resources/compiler.properties
...classes/com/sun/tools/javac/resources/compiler.properties
+4
-0
test/tools/javac/TryWithResources/T7164542.java
test/tools/javac/TryWithResources/T7164542.java
+44
-0
test/tools/javac/diags/examples/ForeachBadInitialization.java
.../tools/javac/diags/examples/ForeachBadInitialization.java
+31
-0
test/tools/javac/parser/JavacParserTest.java
test/tools/javac/parser/JavacParserTest.java
+6
-3
test/tools/javac/processing/messager/MessagerDiags.java
test/tools/javac/processing/messager/MessagerDiags.java
+131
-0
未找到文件。
src/share/classes/com/sun/tools/javac/comp/Lower.java
浏览文件 @
ef659bfa
...
...
@@ -1606,6 +1606,11 @@ public class Lower extends TreeTranslator {
}
private
JCStatement
makeResourceCloseInvocation
(
JCExpression
resource
)
{
// convert to AutoCloseable if needed
if
(
types
.
asSuper
(
resource
.
type
,
syms
.
autoCloseableType
.
tsym
)
==
null
)
{
resource
=
(
JCExpression
)
convert
(
resource
,
syms
.
autoCloseableType
);
}
// create resource.close() method invocation
JCExpression
resourceClose
=
makeCall
(
resource
,
names
.
close
,
...
...
src/share/classes/com/sun/tools/javac/parser/JavacParser.java
浏览文件 @
ef659bfa
...
...
@@ -2206,10 +2206,15 @@ public class JavacParser implements Parser {
}
else
{
JCExpression
t
=
term
(
EXPR
|
TYPE
);
if
((
lastmode
&
TYPE
)
!=
0
&&
(
token
.
kind
==
IDENTIFIER
||
token
.
kind
==
ASSERT
||
token
.
kind
==
ENUM
))
(
token
.
kind
==
IDENTIFIER
||
token
.
kind
==
ASSERT
||
token
.
kind
==
ENUM
))
{
return
variableDeclarators
(
modifiersOpt
(),
t
,
stats
).
toList
();
else
}
else
if
((
lastmode
&
TYPE
)
!=
0
&&
token
.
kind
==
COLON
)
{
error
(
pos
,
"bad.initializer"
,
"for-loop"
);
return
List
.
of
((
JCStatement
)
F
.
at
(
pos
).
VarDef
(
null
,
null
,
t
,
null
));
}
else
{
return
moreStatementExpressions
(
pos
,
t
,
stats
).
toList
();
}
}
}
...
...
src/share/classes/com/sun/tools/javac/processing/JavacMessager.java
浏览文件 @
ef659bfa
/*
* Copyright (c) 2005, 201
0
, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2005, 201
2
, 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
...
...
@@ -99,6 +99,7 @@ public class JavacMessager implements Messager {
if
(
treeTop
!=
null
)
{
newSource
=
treeTop
.
snd
.
sourcefile
;
if
(
newSource
!=
null
)
{
// save the old version and reinstate it later
oldSource
=
log
.
useSource
(
newSource
);
pos
=
treeTop
.
fst
.
pos
();
}
...
...
@@ -131,7 +132,8 @@ public class JavacMessager implements Messager {
break
;
}
}
finally
{
if
(
oldSource
!=
null
)
// reinstate the saved version, only if it was saved earlier
if
(
newSource
!=
null
)
log
.
useSource
(
oldSource
);
}
}
...
...
src/share/classes/com/sun/tools/javac/resources/compiler.properties
浏览文件 @
ef659bfa
...
...
@@ -137,6 +137,10 @@ compiler.err.array.req.but.found=\
compiler.err.attribute.value.must.be.constant
=
\
attribute value must be constant
# 0: statement type
compiler.err.bad.initializer
=
\
bad initializer for {0}
compiler.err.break.outside.switch.loop
=
\
break outside switch or loop
...
...
test/tools/javac/TryWithResources/T7164542.java
0 → 100644
浏览文件 @
ef659bfa
/*
* Copyright (c) 2012, 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 7164542
* @summary try-with-resources: problem with intersection types
* @compile T7164542.java
*/
public
class
T7164542
{
public
static
<
S
extends
Readable
&
AutoCloseable
,
T
extends
Appendable
&
AutoCloseable
>
void
copy
(
S
s
,
T
t
,
int
size
)
throws
Exception
{
/*
* compiler used to fail here with:
* symbol: method close()
* location: interface Readable
* Fatal Error: Unable to find method close
*/
try
(
S
src
=
s
;
T
trg
=
t
)
{
}
}
}
test/tools/javac/diags/examples/ForeachBadInitialization.java
0 → 100644
浏览文件 @
ef659bfa
/*
* Copyright (c) 2012, 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.
*/
// key: compiler.err.bad.initializer
import
java.util.List
;
class
ForeachBadInitialization
{
void
m
()
{
List
<
String
>
s
=
null
;
for
(
a
:
s
)
{}
}
}
test/tools/javac/parser/JavacParserTest.java
浏览文件 @
ef659bfa
...
...
@@ -23,7 +23,7 @@
/*
* @test
* @bug 7073631
* @bug 7073631
7159445
* @summary tests error and diagnostics positions
* @author Jan Lahoda
*/
...
...
@@ -875,6 +875,7 @@ public class JavacParserTest extends TestCase {
testMissingClassError
();
testSwitchError
();
testMethodError
();
testErrorRecoveryForEnhancedForLoop142381
();
}
public
static
void
main
(
String
...
args
)
throws
IOException
{
...
...
@@ -892,8 +893,10 @@ abstract class TestCase {
}
}
void
assertFalse
(
String
message
,
boolean
empty
)
{
throw
new
UnsupportedOperationException
(
"Not yet implemented"
);
void
assertFalse
(
String
message
,
boolean
bvalue
)
{
if
(
bvalue
==
true
)
{
fail
(
message
);
}
}
void
assertEquals
(
String
message
,
int
i
,
long
l
)
{
...
...
test/tools/javac/processing/messager/MessagerDiags.java
0 → 100644
浏览文件 @
ef659bfa
/*
* Copyright (c) 2012, 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. Oracle designates this
* particular file as subject to the "Classpath" exception as provided
* by Oracle 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 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 7166010
* @summary warnings printed by annotation processors uses incorrect source
*/
import
com.sun.source.util.JavacTask
;
import
java.io.IOException
;
import
java.net.URI
;
import
java.util.ArrayList
;
import
java.util.Arrays
;
import
java.util.LinkedList
;
import
java.util.List
;
import
java.util.Set
;
import
javax.annotation.processing.AbstractProcessor
;
import
javax.annotation.processing.Messager
;
import
javax.annotation.processing.RoundEnvironment
;
import
javax.annotation.processing.SupportedAnnotationTypes
;
import
javax.annotation.processing.SupportedSourceVersion
;
import
javax.lang.model.SourceVersion
;
import
javax.lang.model.element.Element
;
import
javax.lang.model.element.TypeElement
;
import
javax.tools.Diagnostic
;
import
javax.tools.DiagnosticCollector
;
import
javax.tools.JavaCompiler
;
import
javax.tools.JavaFileObject
;
import
javax.tools.SimpleJavaFileObject
;
import
javax.tools.ToolProvider
;
import
static
javax
.
tools
.
Diagnostic
.
Kind
.*;
import
static
javax
.
tools
.
JavaFileObject
.
Kind
.*;
@SupportedSourceVersion
(
SourceVersion
.
RELEASE_6
)
@SupportedAnnotationTypes
(
"*"
)
public
class
MessagerDiags
extends
AbstractProcessor
{
static
final
String
CNAME
=
"Test"
;
static
final
String
TEST_JAVA
=
CNAME
+
".java"
;
static
final
String
TEST_JAVA_URI_NAME
=
"myfo:/"
+
TEST_JAVA
;
static
final
String
WRN_NO_SOURCE
=
"warning without source"
;
static
final
String
WRN_WITH_SOURCE
=
"warning with source"
;
static
final
String
NONE
=
"<none>"
;
static
final
String
[]
EXPECTED
=
{
NONE
+
":-1--1:"
+
WRN_NO_SOURCE
,
TEST_JAVA
+
":0-13:"
+
WRN_WITH_SOURCE
,
NONE
+
":-1--1:"
+
WRN_NO_SOURCE
};
@Override
public
boolean
process
(
Set
<?
extends
TypeElement
>
annotations
,
RoundEnvironment
roundEnv
)
{
Messager
messager
=
processingEnv
.
getMessager
();
for
(
Element
e
:
roundEnv
.
getRootElements
())
{
messager
.
printMessage
(
WARNING
,
WRN_NO_SOURCE
);
messager
.
printMessage
(
WARNING
,
WRN_WITH_SOURCE
,
e
);
messager
.
printMessage
(
WARNING
,
WRN_NO_SOURCE
);
}
return
false
;
}
public
static
void
main
(
String
...
args
)
throws
IOException
{
final
String
bootPath
=
System
.
getProperty
(
"sun.boot.class.path"
);
final
JavaCompiler
tool
=
ToolProvider
.
getSystemJavaCompiler
();
assert
tool
!=
null
;
DiagnosticCollector
<
JavaFileObject
>
dc
=
new
DiagnosticCollector
<>();
List
<
String
>
options
=
new
LinkedList
<>();
options
.
addAll
(
Arrays
.
asList
(
"-bootclasspath"
,
bootPath
,
"-source"
,
"1.6"
,
"-classpath"
,
System
.
getProperty
(
"java.class.path"
)));
options
.
addAll
(
Arrays
.
asList
(
"-processor"
,
MessagerDiags
.
class
.
getName
()));
JavacTask
ct
=
(
JavacTask
)
tool
.
getTask
(
null
,
null
,
dc
,
options
,
null
,
Arrays
.
asList
(
new
MyFileObject
(
"class "
+
CNAME
+
" {}"
)));
ct
.
analyze
();
List
<
String
>
obtainedErrors
=
new
ArrayList
<>();
for
(
Diagnostic
<?
extends
JavaFileObject
>
d
:
dc
.
getDiagnostics
())
{
String
dSource
;
if
(
d
.
getSource
()
!=
null
)
{
dSource
=
d
.
getSource
().
toUri
().
getPath
();
dSource
=
dSource
.
substring
(
dSource
.
lastIndexOf
(
'/'
)
+
1
);
}
else
{
dSource
=
NONE
;
}
obtainedErrors
.
add
(
dSource
+
":"
+
d
.
getStartPosition
()
+
"-"
+
d
.
getEndPosition
()
+
":"
+
d
.
getMessage
(
null
));
}
List
<
String
>
expectedErrors
=
Arrays
.
asList
(
EXPECTED
);
if
(!
expectedErrors
.
equals
(
obtainedErrors
))
{
System
.
err
.
println
(
"Expected: "
+
expectedErrors
);
System
.
err
.
println
(
"Obtained: "
+
obtainedErrors
);
throw
new
AssertionError
(
"Messages don't match"
);
}
}
static
class
MyFileObject
extends
SimpleJavaFileObject
{
private
String
text
;
public
MyFileObject
(
String
text
)
{
super
(
URI
.
create
(
TEST_JAVA_URI_NAME
),
SOURCE
);
this
.
text
=
text
;
}
@Override
public
CharSequence
getCharContent
(
boolean
ignoreEncodingErrors
)
{
return
text
;
}
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录