Class SourceCodeAnalysis
- Since:
- 9
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic enumA span attribute which can be used to derive a coloring.static enumDescribes the completeness of the given input.static interfaceThe result ofanalyzeCompletion(String input).static interfaceA documentation for a candidate for continuation of the given user's input.static final recordAssigns attributes usable for coloring to spans inside a snippet.static final classList of possible qualified names.static interfaceThe wrapping of a snippet of Java source into valid top-level Java source.static interfaceA candidate for continuation of the given user's input.
- 
Method SummaryModifier and TypeMethodDescriptionabstract SourceCodeAnalysis.CompletionInfoanalyzeCompletion(String input) Given an input string, find the first snippet of code (one statement, definition, import, or expression) and evaluate if it is complete.abstract StringanalyzeType(String code, int cursor) Infer the type of the given expression.abstract List<SourceCodeAnalysis.Suggestion> completionSuggestions(String input, int cursor, int[] anchor) Compute possible follow-ups for the given input.abstract Collection<Snippet> dependents(Snippet snippet) Returns a collection ofSnippets which might need updating if the givenSnippetis updated.abstract List<SourceCodeAnalysis.Documentation> documentation(String input, int cursor, boolean computeJavadoc) Compute documentation for the given user's input.abstract List<SourceCodeAnalysis.Highlight> highlights(String snippet) Returns a collection ofHighlights which can be used to color the given snippet.abstract SourceCodeAnalysis.QualifiedNameslistQualifiedNames(String code, int cursor) List qualified names known for the simple name in the given code immediately to the left of the given cursor position.sourceToSnippets(String input) Converts the source code of a snippet into aSnippetobject (or list ofSnippetobjects in the case of some var declarations, e.g.: int x, y, z;).abstract SourceCodeAnalysis.SnippetWrapperReturns the wrapper information for theSnippet.abstract List<SourceCodeAnalysis.SnippetWrapper> Returns the wrapper information for the snippet within the input source string.
- 
Method Details- 
analyzeCompletionGiven an input string, find the first snippet of code (one statement, definition, import, or expression) and evaluate if it is complete.- Parameters:
- input- the input source string
- Returns:
- a CompletionInfo instance with location and completeness info
 
- 
completionSuggestionspublic abstract List<SourceCodeAnalysis.Suggestion> completionSuggestions(String input, int cursor, int[] anchor) Compute possible follow-ups for the given input. Uses information from the currentJShellstate, including type information, to filter the suggestions.- Parameters:
- input- the user input, so far
- cursor- the current position of the cursors in the given- inputtext
- anchor- outgoing parameter - when an option will be completed, the text between the anchor and cursor will be deleted and replaced with the given option
- Returns:
- list of candidate continuations of the given input.
 
- 
documentationpublic abstract List<SourceCodeAnalysis.Documentation> documentation(String input, int cursor, boolean computeJavadoc) Compute documentation for the given user's input. MultipleDocumentationobjects may be returned when multiple elements match the user's input (like for overloaded methods).- Parameters:
- input- the snippet the user wrote so far
- cursor- the current position of the cursors in the given- inputtext
- computeJavadoc- true if the javadoc for the given input should be computed in addition to the signature
- Returns:
- the documentations for the given user's input, if multiple elements match the input,
         multiple Documentationobjects are returned.
 
- 
analyzeTypeInfer the type of the given expression. The expression spans from the beginning ofcodeto the givencursorposition. Returns null if the type of the expression cannot be inferred.- Parameters:
- code- the expression for which the type should be inferred
- cursor- current cursor position in the given code
- Returns:
- the inferred type, or null if it cannot be inferred
 
- 
listQualifiedNamesList qualified names known for the simple name in the given code immediately to the left of the given cursor position. The qualified names are gathered by inspecting the classpath used by eval (seeJShell.addToClasspath(java.lang.String)).- Parameters:
- code- the expression for which the candidate qualified names should be computed
- cursor- current cursor position in the given code
- Returns:
- the known qualified names
 
- 
wrapperReturns the wrapper information for theSnippet. The wrapper changes as the environment changes, so calls to this method at different times may yield different results.- Parameters:
- snippet- the- Snippetfrom which to retrieve the wrapper
- Returns:
- information on the wrapper
 
- 
wrappersReturns the wrapper information for the snippet within the input source string.Wrapper information for malformed and incomplete snippets also generate wrappers. The list is in snippet encounter order. The wrapper changes as the environment changes, so calls to this method at different times may yield different results. The input should be exactly one complete snippet of source code, that is, one expression, statement, variable declaration, method declaration, class declaration, or import. To break arbitrary input into individual complete snippets, use analyzeCompletion(String).The wrapper may not match that returned by wrapper(Snippet), were the source converted to aSnippet.- Parameters:
- input- the source input from which to generate wrappers
- Returns:
- a list of wrapper information
 
- 
sourceToSnippetsConverts the source code of a snippet into aSnippetobject (or list ofSnippetobjects in the case of some var declarations, e.g.: int x, y, z;). Does not install the snippets: declarations are not accessible by other snippets; imports are not added. Does not execute the snippets.Queries may be done on the Snippetobject. TheSnippet.id()will be"*UNASSOCIATED*". The returned snippets are not associated with theJShellinstance, so attempts to pass them toJShellmethods will throw anIllegalArgumentException. They will not appear in queries for snippets -- for example,JShell.snippets().Restrictions on the input are as in JShell.eval.Only preliminary compilation is performed, sufficient to build the Snippet. Snippets known to be erroneous, are returned asErroneousSnippet, other snippets may or may not be in error.- Parameters:
- input- The input String to convert
- Returns:
- usually a singleton list of Snippet, but may be empty or multiple
- Throws:
- IllegalStateException- if the- JShellinstance is closed.
 
- 
dependentsReturns a collection ofSnippets which might need updating if the givenSnippetis updated. The returned collection is designed to be inclusive and may include many false positives.- Parameters:
- snippet- the- Snippetwhose dependents are requested
- Returns:
- the collection of dependents
 
- 
highlightsReturns a collection ofHighlights which can be used to color the given snippet.The returned Highlights do not overlap, and are sorted by their start position.- Parameters:
- snippet- the snippet for which the- Highlights should be computed
- Returns:
- the computed Highlights.
- Since:
- 19
 
 
-