Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell11
提交
6f495a22
D
dragonwell11
项目概览
openanolis
/
dragonwell11
通知
7
Star
2
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
dragonwell11
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
6f495a22
编写于
5月 14, 2013
作者:
A
attila
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
8011718: binding already bound function with extra arguments fails
Reviewed-by: jlaskey, sundar
上级
bbe169ef
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
53 addition
and
4 deletion
+53
-4
nashorn/src/jdk/nashorn/internal/runtime/ScriptFunctionData.java
.../src/jdk/nashorn/internal/runtime/ScriptFunctionData.java
+5
-4
nashorn/test/script/basic/JDK-8011718.js
nashorn/test/script/basic/JDK-8011718.js
+46
-0
nashorn/test/script/basic/JDK-8011718.js.EXPECTED
nashorn/test/script/basic/JDK-8011718.js.EXPECTED
+2
-0
未找到文件。
nashorn/src/jdk/nashorn/internal/runtime/ScriptFunctionData.java
浏览文件 @
6f495a22
...
@@ -25,14 +25,13 @@
...
@@ -25,14 +25,13 @@
package
jdk.nashorn.internal.runtime
;
package
jdk.nashorn.internal.runtime
;
import
static
jdk
.
nashorn
.
internal
.
lookup
.
Lookup
.
MH
;
import
static
jdk
.
nashorn
.
internal
.
runtime
.
ECMAErrors
.
typeError
;
import
static
jdk
.
nashorn
.
internal
.
runtime
.
ECMAErrors
.
typeError
;
import
static
jdk
.
nashorn
.
internal
.
runtime
.
ScriptRuntime
.
UNDEFINED
;
import
static
jdk
.
nashorn
.
internal
.
runtime
.
ScriptRuntime
.
UNDEFINED
;
import
static
jdk
.
nashorn
.
internal
.
lookup
.
Lookup
.
MH
;
import
java.lang.invoke.MethodHandle
;
import
java.lang.invoke.MethodHandle
;
import
java.lang.invoke.MethodHandles
;
import
java.lang.invoke.MethodHandles
;
import
java.lang.invoke.MethodType
;
import
java.lang.invoke.MethodType
;
import
jdk.nashorn.internal.runtime.linker.JavaAdapterFactory
;
import
jdk.nashorn.internal.runtime.linker.JavaAdapterFactory
;
/**
/**
...
@@ -389,7 +388,9 @@ public abstract class ScriptFunctionData {
...
@@ -389,7 +388,9 @@ public abstract class ScriptFunctionData {
boundInvoker
=
noArgBoundInvoker
;
boundInvoker
=
noArgBoundInvoker
;
}
}
}
else
{
}
else
{
final
Object
[]
boundArgs
=
new
Object
[
Math
.
min
(
originalInvoker
.
type
().
parameterCount
(),
args
.
length
+
(
isTargetBound
?
0
:
(
needsCallee
?
2
:
1
)))];
// If target is already bound, insert additional bound arguments after "this" argument, at position 1.
final
int
argInsertPos
=
isTargetBound
?
1
:
0
;
final
Object
[]
boundArgs
=
new
Object
[
Math
.
min
(
originalInvoker
.
type
().
parameterCount
()
-
argInsertPos
,
args
.
length
+
(
isTargetBound
?
0
:
(
needsCallee
?
2
:
1
)))];
int
next
=
0
;
int
next
=
0
;
if
(!
isTargetBound
)
{
if
(!
isTargetBound
)
{
if
(
needsCallee
)
{
if
(
needsCallee
)
{
...
@@ -403,7 +404,7 @@ public abstract class ScriptFunctionData {
...
@@ -403,7 +404,7 @@ public abstract class ScriptFunctionData {
// "this" will get dropped anyway by the target invoker. We previously asserted that already bound functions
// "this" will get dropped anyway by the target invoker. We previously asserted that already bound functions
// don't take a callee parameter, so we can know that the signature is (this[, args...]) therefore args
// don't take a callee parameter, so we can know that the signature is (this[, args...]) therefore args
// start at position 1. If the function is not bound, we start inserting arguments at position 0.
// start at position 1. If the function is not bound, we start inserting arguments at position 0.
boundInvoker
=
MH
.
insertArguments
(
originalInvoker
,
isTargetBound
?
1
:
0
,
boundArgs
);
boundInvoker
=
MH
.
insertArguments
(
originalInvoker
,
argInsertPos
,
boundArgs
);
}
}
if
(
isTargetBound
)
{
if
(
isTargetBound
)
{
...
...
nashorn/test/script/basic/JDK-8011718.js
0 → 100644
浏览文件 @
6f495a22
/*
* Copyright (c) 2010, 2013, 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.
*/
/**
* JDK-8011718: binding already bound function with extra arguments fails.
*
* @test
* @run
*/
var
obj
=
{
hello
:
"
From obj
"
,
};
var
obj2
=
{
hello
:
"
From obj2
"
,
};
function
doit
(
cb
){
cb
();
var
cb2
=
cb
.
bind
(
obj2
,
"
This one is not acccepted
"
);
cb2
();
}
doit
(
function
(){
print
(
this
.
hello
);
}.
bind
(
obj
));
nashorn/test/script/basic/JDK-8011718.js.EXPECTED
0 → 100644
浏览文件 @
6f495a22
From obj
From obj
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录