Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
fa3ea526
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看板
提交
fa3ea526
编写于
5月 21, 2015
作者:
R
robm
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
8077822: javac does not recognize '*.java' as file if '-J' option is specified
Reviewed-by: ksrini
上级
023fdb9f
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
40 addition
and
6 deletion
+40
-6
src/windows/bin/java_md.c
src/windows/bin/java_md.c
+29
-5
test/tools/launcher/Arrrghs.java
test/tools/launcher/Arrrghs.java
+11
-1
未找到文件。
src/windows/bin/java_md.c
浏览文件 @
fa3ea526
...
...
@@ -1403,6 +1403,26 @@ ProcessPlatformOption(const char *arg)
return
JNI_FALSE
;
}
int
filterArgs
(
StdArg
*
stdargs
,
const
int
nargc
,
StdArg
**
pargv
)
{
StdArg
*
argv
=
NULL
;
int
nargs
=
0
;
int
i
;
/* Copy the non-vm args */
for
(
i
=
0
;
i
<
nargc
;
i
++
)
{
const
char
*
arg
=
stdargs
[
i
].
arg
;
if
(
arg
[
0
]
==
'-'
&&
arg
[
1
]
==
'J'
)
continue
;
argv
=
(
StdArg
*
)
JLI_MemRealloc
(
argv
,
(
nargs
+
1
)
*
sizeof
(
StdArg
));
argv
[
nargs
].
arg
=
JLI_StringDup
(
arg
);
argv
[
nargs
].
has_wildcard
=
stdargs
[
i
].
has_wildcard
;
nargs
++
;
}
*
pargv
=
argv
;
return
nargs
;
}
/*
* At this point we have the arguments to the application, and we need to
* check with original stdargs in order to compare which of these truly
...
...
@@ -1417,8 +1437,9 @@ CreateApplicationArgs(JNIEnv *env, char **strv, int argc)
char
*
ostart
,
*
astart
,
**
nargv
;
jboolean
needs_expansion
=
JNI_FALSE
;
jmethodID
mid
;
int
stdargc
;
int
filteredargc
,
stdargc
;
StdArg
*
stdargs
;
StdArg
*
filteredargs
;
jclass
cls
=
GetLauncherHelperClass
(
env
);
NULL_CHECK0
(
cls
);
...
...
@@ -1429,6 +1450,8 @@ CreateApplicationArgs(JNIEnv *env, char **strv, int argc)
stdargs
=
JLI_GetStdArgs
();
stdargc
=
JLI_GetStdArgc
();
filteredargc
=
filterArgs
(
stdargs
,
stdargc
,
&
filteredargs
);
// sanity check, this should never happen
if
(
argc
>
stdargc
)
{
JLI_TraceLauncher
(
"Warning: app args is larger than the original, %d %d
\n
"
,
argc
,
stdargc
);
...
...
@@ -1437,8 +1460,8 @@ CreateApplicationArgs(JNIEnv *env, char **strv, int argc)
}
// sanity check, match the args we have, to the holy grail
idx
=
st
dargc
-
argc
;
ostart
=
st
dargs
[
idx
].
arg
;
idx
=
filtere
dargc
-
argc
;
ostart
=
filtere
dargs
[
idx
].
arg
;
astart
=
strv
[
0
];
// sanity check, ensure that the first argument of the arrays are the same
if
(
JLI_StrCmp
(
ostart
,
astart
)
!=
0
)
{
...
...
@@ -1451,8 +1474,8 @@ CreateApplicationArgs(JNIEnv *env, char **strv, int argc)
// make a copy of the args which will be expanded in java if required.
nargv
=
(
char
**
)
JLI_MemAlloc
(
argc
*
sizeof
(
char
*
));
for
(
i
=
0
,
j
=
idx
;
i
<
argc
;
i
++
,
j
++
)
{
jboolean
arg_expand
=
(
JLI_StrCmp
(
st
dargs
[
j
].
arg
,
strv
[
i
])
==
0
)
?
st
dargs
[
j
].
has_wildcard
jboolean
arg_expand
=
(
JLI_StrCmp
(
filtere
dargs
[
j
].
arg
,
strv
[
i
])
==
0
)
?
filtere
dargs
[
j
].
has_wildcard
:
JNI_FALSE
;
if
(
needs_expansion
==
JNI_FALSE
)
needs_expansion
=
arg_expand
;
...
...
@@ -1489,5 +1512,6 @@ CreateApplicationArgs(JNIEnv *env, char **strv, int argc)
JLI_MemFree
(
nargv
[
i
]);
}
JLI_MemFree
(
nargv
);
JLI_MemFree
(
filteredargs
);
return
outArray
;
}
test/tools/launcher/Arrrghs.java
浏览文件 @
fa3ea526
...
...
@@ -24,7 +24,7 @@
/**
* @test
* @bug 5030233 6214916 6356475 6571029 6684582 6742159 4459600 6758881 6753938
* 6894719 6968053 7151434 7146424 8007333
* 6894719 6968053 7151434 7146424 8007333
8077822
* @summary Argument parsing validation.
* @compile -XDignore.symbol.file Arrrghs.java
* @run main/othervm Arrrghs
...
...
@@ -431,6 +431,16 @@ public class Arrrghs extends TestHelper {
throw
new
RuntimeException
(
"Error: compiling java wildcards"
);
}
// test if javac (the command) can compile *.java with a vmoption
tr
=
doExec
(
javacCmd
,
"-cp"
,
"."
,
"-J-showversion"
,
"-J-Dsomeproperty=foo"
,
libDir
.
getName
()
+
File
.
separator
+
"*.java"
);
if
(!
tr
.
isOK
())
{
System
.
out
.
println
(
tr
);
throw
new
RuntimeException
(
"Error: compiling java wildcards with vmoptions"
);
}
// use the jar cmd to create jars using the ? wildcard
File
jarFoo
=
new
File
(
libDir
,
"Foo.jar"
);
tr
=
doExec
(
jarCmd
,
"cvf"
,
jarFoo
.
getAbsolutePath
(),
"lib"
+
File
.
separator
+
"F?o.class"
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录