Merge
This commit is contained in:
commit
83266bbadf
@ -1705,9 +1705,26 @@ public final class Global extends ScriptObject implements GlobalObject, Scope {
|
|||||||
initScripting(env);
|
initScripting(env);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Context.DEBUG && System.getSecurityManager() == null) {
|
if (Context.DEBUG) {
|
||||||
|
boolean debugOkay;
|
||||||
|
final SecurityManager sm = System.getSecurityManager();
|
||||||
|
if (sm != null) {
|
||||||
|
try {
|
||||||
|
sm.checkPermission(new RuntimePermission(Context.NASHORN_DEBUG_MODE));
|
||||||
|
debugOkay = true;
|
||||||
|
} catch (final SecurityException ignored) {
|
||||||
|
// if no permission, don't initialize Debug object
|
||||||
|
debugOkay = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
} else {
|
||||||
|
debugOkay = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (debugOkay) {
|
||||||
initDebug();
|
initDebug();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
copyBuiltins();
|
copyBuiltins();
|
||||||
|
|
||||||
|
@ -85,6 +85,10 @@ public final class NativeError extends ScriptObject {
|
|||||||
@Property(attributes = Attribute.NOT_ENUMERABLE, where = Where.PROTOTYPE)
|
@Property(attributes = Attribute.NOT_ENUMERABLE, where = Where.PROTOTYPE)
|
||||||
public Object message;
|
public Object message;
|
||||||
|
|
||||||
|
/** Nashorn extension: underlying exception */
|
||||||
|
@Property(attributes = Attribute.NOT_ENUMERABLE)
|
||||||
|
public Object nashornException;
|
||||||
|
|
||||||
// initialized by nasgen
|
// initialized by nasgen
|
||||||
private static PropertyMap $nasgenmap$;
|
private static PropertyMap $nasgenmap$;
|
||||||
|
|
||||||
|
@ -55,6 +55,10 @@ public final class NativeEvalError extends ScriptObject {
|
|||||||
@Property(attributes = Attribute.NOT_ENUMERABLE, where = Where.PROTOTYPE)
|
@Property(attributes = Attribute.NOT_ENUMERABLE, where = Where.PROTOTYPE)
|
||||||
public Object message;
|
public Object message;
|
||||||
|
|
||||||
|
/** Nashorn extension: underlying exception */
|
||||||
|
@Property(attributes = Attribute.NOT_ENUMERABLE)
|
||||||
|
public Object nashornException;
|
||||||
|
|
||||||
// initialized by nasgen
|
// initialized by nasgen
|
||||||
private static PropertyMap $nasgenmap$;
|
private static PropertyMap $nasgenmap$;
|
||||||
|
|
||||||
|
@ -55,6 +55,10 @@ public final class NativeRangeError extends ScriptObject {
|
|||||||
@Property(attributes = Attribute.NOT_ENUMERABLE, where = Where.PROTOTYPE)
|
@Property(attributes = Attribute.NOT_ENUMERABLE, where = Where.PROTOTYPE)
|
||||||
public Object message;
|
public Object message;
|
||||||
|
|
||||||
|
/** Nashorn extension: underlying exception */
|
||||||
|
@Property(attributes = Attribute.NOT_ENUMERABLE)
|
||||||
|
public Object nashornException;
|
||||||
|
|
||||||
// initialized by nasgen
|
// initialized by nasgen
|
||||||
private static PropertyMap $nasgenmap$;
|
private static PropertyMap $nasgenmap$;
|
||||||
|
|
||||||
|
@ -55,6 +55,10 @@ public final class NativeReferenceError extends ScriptObject {
|
|||||||
@Property(attributes = Attribute.NOT_ENUMERABLE, where = Where.PROTOTYPE)
|
@Property(attributes = Attribute.NOT_ENUMERABLE, where = Where.PROTOTYPE)
|
||||||
public Object message;
|
public Object message;
|
||||||
|
|
||||||
|
/** Nashorn extension: underlying exception */
|
||||||
|
@Property(attributes = Attribute.NOT_ENUMERABLE)
|
||||||
|
public Object nashornException;
|
||||||
|
|
||||||
// initialized by nasgen
|
// initialized by nasgen
|
||||||
private static PropertyMap $nasgenmap$;
|
private static PropertyMap $nasgenmap$;
|
||||||
|
|
||||||
|
@ -55,6 +55,10 @@ public final class NativeSyntaxError extends ScriptObject {
|
|||||||
@Property(attributes = Attribute.NOT_ENUMERABLE, where = Where.PROTOTYPE)
|
@Property(attributes = Attribute.NOT_ENUMERABLE, where = Where.PROTOTYPE)
|
||||||
public Object message;
|
public Object message;
|
||||||
|
|
||||||
|
/** Nashorn extension: underlying exception */
|
||||||
|
@Property(attributes = Attribute.NOT_ENUMERABLE)
|
||||||
|
public Object nashornException;
|
||||||
|
|
||||||
// initialized by nasgen
|
// initialized by nasgen
|
||||||
private static PropertyMap $nasgenmap$;
|
private static PropertyMap $nasgenmap$;
|
||||||
|
|
||||||
|
@ -55,6 +55,10 @@ public final class NativeTypeError extends ScriptObject {
|
|||||||
@Property(attributes = Attribute.NOT_ENUMERABLE, where = Where.PROTOTYPE)
|
@Property(attributes = Attribute.NOT_ENUMERABLE, where = Where.PROTOTYPE)
|
||||||
public Object message;
|
public Object message;
|
||||||
|
|
||||||
|
/** Nashorn extension: underlying exception */
|
||||||
|
@Property(attributes = Attribute.NOT_ENUMERABLE)
|
||||||
|
public Object nashornException;
|
||||||
|
|
||||||
// initialized by nasgen
|
// initialized by nasgen
|
||||||
private static PropertyMap $nasgenmap$;
|
private static PropertyMap $nasgenmap$;
|
||||||
|
|
||||||
|
@ -54,6 +54,10 @@ public final class NativeURIError extends ScriptObject {
|
|||||||
@Property(attributes = Attribute.NOT_ENUMERABLE, where = Where.PROTOTYPE)
|
@Property(attributes = Attribute.NOT_ENUMERABLE, where = Where.PROTOTYPE)
|
||||||
public Object message;
|
public Object message;
|
||||||
|
|
||||||
|
/** Nashorn extension: underlying exception */
|
||||||
|
@Property(attributes = Attribute.NOT_ENUMERABLE)
|
||||||
|
public Object nashornException;
|
||||||
|
|
||||||
// initialized by nasgen
|
// initialized by nasgen
|
||||||
private static PropertyMap $nasgenmap$;
|
private static PropertyMap $nasgenmap$;
|
||||||
|
|
||||||
|
@ -91,6 +91,11 @@ public final class Context {
|
|||||||
*/
|
*/
|
||||||
public static final String NASHORN_JAVA_REFLECTION = "nashorn.JavaReflection";
|
public static final String NASHORN_JAVA_REFLECTION = "nashorn.JavaReflection";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Permission to enable nashorn debug mode.
|
||||||
|
*/
|
||||||
|
public static final String NASHORN_DEBUG_MODE = "nashorn.debugMode";
|
||||||
|
|
||||||
// nashorn load psuedo URL prefixes
|
// nashorn load psuedo URL prefixes
|
||||||
private static final String LOAD_CLASSPATH = "classpath:";
|
private static final String LOAD_CLASSPATH = "classpath:";
|
||||||
private static final String LOAD_FX = "fx:";
|
private static final String LOAD_FX = "fx:";
|
||||||
|
@ -33,7 +33,6 @@ import javax.script.ScriptException;
|
|||||||
import jdk.nashorn.api.scripting.NashornException;
|
import jdk.nashorn.api.scripting.NashornException;
|
||||||
import jdk.nashorn.internal.codegen.CompilerConstants.Call;
|
import jdk.nashorn.internal.codegen.CompilerConstants.Call;
|
||||||
import jdk.nashorn.internal.codegen.CompilerConstants.FieldAccess;
|
import jdk.nashorn.internal.codegen.CompilerConstants.FieldAccess;
|
||||||
import jdk.nashorn.internal.objects.NativeError;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Exception used to implement ECMAScript "throw" from scripts. The actual thrown
|
* Exception used to implement ECMAScript "throw" from scripts. The actual thrown
|
||||||
|
72
nashorn/test/script/trusted/JDK-8032060.js
Normal file
72
nashorn/test/script/trusted/JDK-8032060.js
Normal file
@ -0,0 +1,72 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2014, 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-8032060: PropertyMap of Error objects is not stable
|
||||||
|
*
|
||||||
|
* @test
|
||||||
|
* @option -Dnashorn.debug=true
|
||||||
|
* @fork
|
||||||
|
* @run
|
||||||
|
*/
|
||||||
|
|
||||||
|
function checkMap(e1, e2) {
|
||||||
|
if (! Debug.identical(Debug.map(e1), Debug.map(e2))) {
|
||||||
|
fail("e1 and e2 have different maps");
|
||||||
|
}
|
||||||
|
|
||||||
|
var m1, m2;
|
||||||
|
|
||||||
|
try {
|
||||||
|
throw e1
|
||||||
|
} catch (e) {
|
||||||
|
m1 = Debug.map(e)
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
throw e2
|
||||||
|
} catch (e) {
|
||||||
|
m2 = Debug.map(e)
|
||||||
|
}
|
||||||
|
|
||||||
|
if (! Debug.identical(m1, m2)) {
|
||||||
|
fail("e1 and e2 have different maps after being thrown");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
checkMap(new Error(), new Error());
|
||||||
|
checkMap(new EvalError(), new EvalError());
|
||||||
|
checkMap(new RangeError(), new RangeError());
|
||||||
|
checkMap(new ReferenceError(), new ReferenceError());
|
||||||
|
checkMap(new SyntaxError(), new SyntaxError());
|
||||||
|
checkMap(new TypeError(), new TypeError());
|
||||||
|
checkMap(new URIError(), new URIError());
|
||||||
|
|
||||||
|
// now try with message param
|
||||||
|
checkMap(new Error("x"), new Error("y"));
|
||||||
|
checkMap(new EvalError("x"), new EvalError("y"));
|
||||||
|
checkMap(new RangeError("x"), new RangeError("y"));
|
||||||
|
checkMap(new ReferenceError("x"), new ReferenceError("y"));
|
||||||
|
checkMap(new SyntaxError("x"), new SyntaxError("y"));
|
||||||
|
checkMap(new TypeError("x"), new TypeError("y"));
|
||||||
|
checkMap(new URIError("x"), new URIError("y"));
|
Loading…
x
Reference in New Issue
Block a user