org.wicketstuff.console.engine.ScalaEngine.scala Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of wicketstuff-console-engine Show documentation
Show all versions of wicketstuff-console-engine Show documentation
This is the 'backend' of Wicket Console which actually executes scripts.
package org.wicketstuff.console.engine
import java.util.Map
import java.io.PrintWriter
import java.io.StringWriter
import java.io.PrintStream
import java.io.ByteArrayOutputStream
import scala.tools.nsc._
import scala.tools.nsc.interpreter._
import scala.tools.nsc.interpreter.{ Results => IR }
class ScalaEngine extends IScriptEngine {
val settings = new Settings
settings.usejavacp.value = true
val interpreter = new IMain(settings)
def execute(script: String): IScriptExecutionResult = {
interpret(script, new java.util.HashMap())
}
def execute(script: String, bindings: Map[String, Object]): IScriptExecutionResult = {
interpret(script, bindings)
}
def interpret(script: String, bindings: Map[String, Object]): IScriptExecutionResult = {
if (script == null || script.trim().equals("")) {
return new DefaultScriptExecutionResult(script, null, "", null);
}
val oldOut: PrintStream = System.out
val oldErr: PrintStream = System.err
val bout: ByteArrayOutputStream = new ByteArrayOutputStream()
val newOut: PrintStream = new PrintStream(bout, false);
var exception: Exception = null
var output: String = null
var returnValue: Any = null
var result: IR.Result = null
try {
val it = bindings.entrySet.iterator
while (it.hasNext) {
val entry = it.next
interpreter.quietBind(NamedParam(entry.getKey, entry.getValue().getClass().getName, entry.getValue()))
}
interpreter.quietBind(NamedParam("$result", null))
System.setOut(newOut)
System.setErr(newOut)
Console.setOut(newOut)
Console.setErr(newOut)
result = interpreter.quietRun(script)
if (result != IR.Success) {
throw new RuntimeException("Script execution failed")
}
returnValue = interpreter.valueOfTerm("$result").getOrElse(null)
} catch {
case ex: Exception => {
exception = ex
ex.printStackTrace()
}
} finally {
System.setOut(oldOut);
System.setErr(oldErr);
Console.setOut(oldOut)
Console.setErr(oldErr)
newOut.close
bout.close
output = bout.toString();
interpreter.reset
}
return new DefaultScriptExecutionResult(script, exception, output, returnValue);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy