diff --git a/src/java.scripting/share/classes/javax/script/AbstractScriptEngine.java b/src/java.scripting/share/classes/javax/script/AbstractScriptEngine.java index 7c9eb00ef10..f34de5cc8bc 100644 --- a/src/java.scripting/share/classes/javax/script/AbstractScriptEngine.java +++ b/src/java.scripting/share/classes/javax/script/AbstractScriptEngine.java @@ -287,7 +287,7 @@ public abstract class AbstractScriptEngine implements ScriptEngine { */ protected ScriptContext getScriptContext(Bindings nn) { - SimpleScriptContext ctxt = new SimpleScriptContext(); + SimpleScriptContext ctxt = new SimpleScriptContext(context.getReader(), context.getWriter(), context.getErrorWriter()); Bindings gs = getBindings(ScriptContext.GLOBAL_SCOPE); if (gs != null) { @@ -301,10 +301,6 @@ public abstract class AbstractScriptEngine implements ScriptEngine { throw new NullPointerException("Engine scope Bindings may not be null."); } - ctxt.setReader(context.getReader()); - ctxt.setWriter(context.getWriter()); - ctxt.setErrorWriter(context.getErrorWriter()); - return ctxt; } diff --git a/src/java.scripting/share/classes/javax/script/CompiledScript.java b/src/java.scripting/share/classes/javax/script/CompiledScript.java index 7fb4157d70a..5dc8738aaf1 100644 --- a/src/java.scripting/share/classes/javax/script/CompiledScript.java +++ b/src/java.scripting/share/classes/javax/script/CompiledScript.java @@ -79,13 +79,10 @@ public abstract class CompiledScript { ScriptContext ctxt = getEngine().getContext(); if (bindings != null) { - SimpleScriptContext tempctxt = new SimpleScriptContext(); + SimpleScriptContext tempctxt = new SimpleScriptContext(ctxt.getReader(), ctxt.getWriter(), ctxt.getErrorWriter()); tempctxt.setBindings(bindings, ScriptContext.ENGINE_SCOPE); tempctxt.setBindings(ctxt.getBindings(ScriptContext.GLOBAL_SCOPE), ScriptContext.GLOBAL_SCOPE); - tempctxt.setWriter(ctxt.getWriter()); - tempctxt.setReader(ctxt.getReader()); - tempctxt.setErrorWriter(ctxt.getErrorWriter()); ctxt = tempctxt; } diff --git a/src/java.scripting/share/classes/javax/script/SimpleScriptContext.java b/src/java.scripting/share/classes/javax/script/SimpleScriptContext.java index 119b3f26fb3..dde6ddc7566 100644 --- a/src/java.scripting/share/classes/javax/script/SimpleScriptContext.java +++ b/src/java.scripting/share/classes/javax/script/SimpleScriptContext.java @@ -86,11 +86,25 @@ public class SimpleScriptContext implements ScriptContext { * Create a {@code SimpleScriptContext}. */ public SimpleScriptContext() { + this(new InputStreamReader(System.in), + new PrintWriter(System.out , true), + new PrintWriter(System.err, true)); engineScope = new SimpleBindings(); globalScope = null; - reader = new InputStreamReader(System.in); - writer = new PrintWriter(System.out , true); - errorWriter = new PrintWriter(System.err, true); + } + + /** + * Package-private constructor to avoid needless creation of reader and writers. + * It is the caller's responsability to initialize the engine scope. + * + * @param reader the reader + * @param writer the writer + * @param errorWriter the error writer + */ + SimpleScriptContext(Reader reader, Writer writer, Writer errorWriter) { + this.reader = reader; + this.writer = writer; + this.errorWriter = errorWriter; } /**