public class JRubyAdapter extends LanguageAdapterBase
LanguageAdapter
that supports the Ruby language as implemented by
JRuby.Modifier and Type | Field and Description |
---|---|
protected org.jruby.Ruby |
compilerRuntime
A shared Ruby runtime instance used for scriptlet preparation.
|
static String |
JRUBY_CLASS_CACHE
The Ruby class cache attribute.
|
static String |
JRUBY_ERR
The switchable standard error attribute for the Ruby runtime.
|
static String |
JRUBY_OUT
The switchable standard output attribute for the Ruby runtime.
|
static String |
JRUBY_RUNTIME
The Ruby runtime instance attribute.
|
static String |
RUBY_CACHE_DIR
The default base directory for cached executables.
|
DEFAULT_EXTENSION, DEFAULT_TAG, EXTENSIONS, LANGUAGE_NAME, LANGUAGE_VERSION, NAME, TAGS, VERSION
Constructor and Description |
---|
JRubyAdapter()
Constructor.
|
Modifier and Type | Method and Description |
---|---|
static ExecutionException |
createExecutionException(org.jruby.exceptions.RaiseException x)
Creates an execution exception with a full stack.
|
Program |
createProgram(String sourceCode,
boolean isScriptlet,
int position,
int startLineNumber,
int startColumnNumber,
Executable executable)
Turns source code into a program.
|
Object |
enter(String entryPointName,
Executable executable,
ExecutionContext executionContext,
Object... arguments)
Enters the executable at a stored, named location.
|
File |
getCacheDir()
The base directory for cached executables.
|
org.jruby.util.ClassCache<org.jruby.ast.executable.Script> |
getRubyClassCache()
The class cache shared between all Ruby runtime instances.
|
org.jruby.Ruby |
getRubyRuntime(ExecutionContext executionContext)
Gets a Ruby runtime instance stored in the execution context, creating it
if it doesn't exist.
|
String |
getSourceCodeForExpressionInclude(String expression,
Executable executable)
Creates source code for including the output of a text-with-scriptlets
document.
|
String |
getSourceCodeForExpressionOutput(String expression,
Executable executable)
Creates source code for outputting a source code expression to standard
output.
|
String |
getSourceCodeForLiteralOutput(String literal,
Executable executable)
Creates source code for outputting literal text to standard output.
|
getAttributes, getLock, getManager, isEphemeral, isThreadSafe, releaseContext, setManager
public static final String JRUBY_RUNTIME
public static final String JRUBY_CLASS_CACHE
public static final String JRUBY_OUT
public static final String JRUBY_ERR
public static final String RUBY_CACHE_DIR
protected final org.jruby.Ruby compilerRuntime
public JRubyAdapter() throws LanguageAdapterException
LanguageAdapterException
- In case of an initialization errorpublic static ExecutionException createExecutionException(org.jruby.exceptions.RaiseException x)
x
- The Ruby exceptionpublic org.jruby.util.ClassCache<org.jruby.ast.executable.Script> getRubyClassCache()
public org.jruby.Ruby getRubyRuntime(ExecutionContext executionContext)
executionContext
- The execution contextpublic File getCacheDir()
public String getSourceCodeForLiteralOutput(String literal, Executable executable) throws ParsingException
LanguageAdapter
getSourceCodeForLiteralOutput
in interface LanguageAdapter
getSourceCodeForLiteralOutput
in class LanguageAdapterBase
literal
- The literal textexecutable
- The executableParsingException
- In case of a parsing errorpublic String getSourceCodeForExpressionOutput(String expression, Executable executable) throws ParsingException
LanguageAdapter
getSourceCodeForExpressionOutput
in interface LanguageAdapter
getSourceCodeForExpressionOutput
in class LanguageAdapterBase
expression
- The source code expressionexecutable
- The executableParsingException
- In case of a parsing errorpublic String getSourceCodeForExpressionInclude(String expression, Executable executable) throws ParsingException
LanguageAdapter
For this to work, the executable must have been created with a container
that supports an inclusion command named according to the language
manager attribute
LanguageManager.CONTAINER_INCLUDE_COMMAND_ATTRIBUTE
.
getSourceCodeForExpressionInclude
in interface LanguageAdapter
getSourceCodeForExpressionInclude
in class LanguageAdapterBase
expression
- The source code expressionexecutable
- The executableParsingException
- In case of a parsing errorLanguageManager.getAttributes()
public Program createProgram(String sourceCode, boolean isScriptlet, int position, int startLineNumber, int startColumnNumber, Executable executable) throws ParsingException
LanguageAdapter
Program.prepare()
on the program.sourceCode
- The source codeisScriptlet
- Whether the source code is a scriptletposition
- The program's position in the executablestartLineNumber
- The line number in the document for where the program's source
code beginsstartColumnNumber
- The column number in the document for where the program's source
code beginsexecutable
- The executableParsingException
- In case of a parsing errorpublic Object enter(String entryPointName, Executable executable, ExecutionContext executionContext, Object... arguments) throws NoSuchMethodException, ParsingException, ExecutionException
LanguageAdapter
enter
in interface LanguageAdapter
enter
in class LanguageAdapterBase
entryPointName
- The entry point nameexecutable
- The executableexecutionContext
- The executable contextarguments
- Optional state to pass to the entry pointNoSuchMethodException
- In case the entry point does not existParsingException
- In case of a parsing errorExecutionException
- In case of an execution errorCopyright © 2009-2015 Three Crickets LLC.