Class Snippet
java.lang.Object
jdk.jshell.Snippet
- Direct Known Subclasses:
ErroneousSnippet, ExpressionSnippet, PersistentSnippet, StatementSnippet
A Snippet represents a snippet of Java source code as passed to
JShell.eval(java.lang.String)
. It is associated only with the
JShell
instance that created it.
An instance of Snippet (including its subclasses) is immutable: an access to
any of its methods will always return the same result.
For information about the current state of the snippet within the JShell
state engine, query JShell
passing the Snippet.
Because it is immutable, Snippet
(and subclasses) is thread-safe.
- Since:
- 9
- See Also:
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic enum
Describes the general kind of snippet.static enum
Describes the current state of a Snippet.static enum
The detailed variety of a snippet. -
Method Summary
Modifier and TypeMethodDescriptionid()
The unique identifier for the snippet.kind()
TheSnippet.Kind
for the snippet.source()
Return the source code of the snippet.subKind()
Return theSnippet.SubKind
of snippet.Methods declared in class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Modifier and TypeMethodDescriptionprotected Object
clone()
Creates and returns a copy of this object.boolean
Indicates whether some other object is "equal to" this one.protected void
finalize()
Deprecated, for removal: This API element is subject to removal in a future version.Finalization is deprecated and subject to removal in a future release.final Class
<?> getClass()
Returns the runtime class of thisObject
.int
hashCode()
Returns a hash code value for this object.final void
notify()
Wakes up a single thread that is waiting on this object's monitor.final void
Wakes up all threads that are waiting on this object's monitor.toString()
Returns a string representation of the object.final void
wait()
Causes the current thread to wait until it is awakened, typically by being notified or interrupted.final void
wait
(long timeoutMillis) Causes the current thread to wait until it is awakened, typically by being notified or interrupted, or until a certain amount of real time has elapsed.final void
wait
(long timeoutMillis, int nanos) Causes the current thread to wait until it is awakened, typically by being notified or interrupted, or until a certain amount of real time has elapsed.
-
Method Details
-
id
The unique identifier for the snippet. No two active snippets will have the same id(). Value of id has no prescribed meaning. The details of how the id is generated and the mechanism to change it is documented inJShell.Builder.idGenerator(BiFunction)
.- Returns:
- the snippet id string.
-
kind
TheSnippet.Kind
for the snippet. Indicates the subclass of Snippet.- Returns:
- the Kind of the snippet
- See Also:
-
subKind
Return theSnippet.SubKind
of snippet. The SubKind is useful for feedback to users.- Returns:
- the SubKind corresponding to this snippet
-
source
Return the source code of the snippet.- Returns:
- the source code corresponding to this snippet
-