Package com.github.javaparser
Class JavaParser
java.lang.Object
com.github.javaparser.JavaParser
Parse Java source code and creates Abstract Syntax Trees.
- Author:
- JĂșlio Vilmar Gesser
- See Also:
StaticJavaParser
-
Constructor Summary
ConstructorsConstructorDescriptionInstantiate the parser with default configuration.JavaParser(ParserConfiguration configuration)
Instantiate the parser. -
Method Summary
Modifier and TypeMethodDescription<N extends Node>
ParseResult<N>parse(ParseStart<N> start, Provider provider)
Parses source code.Deprecated.parse(InputStream in)
parse(InputStream in, Charset encoding)
Parses the Java code contained in theInputStream
and returns aCompilationUnit
that represents it.Parses Java code from a Reader and returns aCompilationUnit
that represents it.Parses the Java code contained in code and returns aCompilationUnit
that represents it.Parses the Java code contained in a file and returns aCompilationUnit
that represents it.Deprecated.set the encoding in theParserConfiguration
parseAnnotation(String annotation)
Parses the Java annotation contained in aString
and returns aAnnotationExpr
that represents it.Parses the Java annotation body declaration(e.g fields or methods) contained in aString
and returns aBodyDeclaration
that represents it.parseBlock(String blockStatement)
<T extends BodyDeclaration<?>>
ParseResult<T>parseBodyDeclaration(String body)
Parses a Java class or interface body declaration(e.g fields or methods) and returns aBodyDeclaration
that represents it.parseClassOrInterfaceType(String type)
Parses a Java class or interface type name and returns aClassOrInterfaceType
that represents it.parseExplicitConstructorInvocationStmt(String statement)
Parses the this(...) and super(...) statements that may occur at the start of a constructor.<T extends Expression>
ParseResult<T>parseExpression(String expression)
Parses the Java expression contained in aString
and returns aExpression
that represents it.parseImport(String importDeclaration)
Parses the Java import contained in aString
and returns aImportDeclaration
that represents it.parseMethodDeclaration(String methodDeclaration)
Parses a method declaration and returns it as a MethodDeclaration.parseModuleDeclaration(String moduleDeclaration)
Parses a module declaration and returns it as a ModuleDeclaration.parseModuleDirective(String moduleDirective)
Parses a module directive and returns it as a ModuleDirective.Parses a qualified name (one that can have "."s in it) and returns it as a Name.parsePackageDeclaration(String packageDeclaration)
Parses a package declaration and returns it as a PackageDeclaration.parseParameter(String parameter)
Parses a single parameter (a type and a name) and returns it as a Parameter.parseResource(ClassLoader classLoader, String path, Charset encoding)
Deprecated.set the encoding in theParserConfiguration
parseResource(String path)
Parses the Java code contained in a resource and returns aCompilationUnit
that represents it.parseResource(String path, Charset encoding)
Deprecated.set the encoding in theParserConfiguration
parseSimpleName(String name)
Parses a simple name (one that can NOT have "."s in it) and returns it as a SimpleName.parseStatement(String statement)
Parses a Java type name and returns aType
that represents it.parseTypeDeclaration(String typeDeclaration)
Parses a type declaration and returns it as a TypeDeclaration.parseTypeParameter(String typeParameter)
Parses a type parameter and returns it as a TypeParameterparseVariableDeclarationExpr(String declaration)
Parses a variable declaration expression and returns aVariableDeclarationExpr
that represents it.
-
Constructor Details
-
JavaParser
public JavaParser()Instantiate the parser with default configuration. Note that parsing can also be done with the static methodsStaticJavaParser
. Creating an instance will reduce setup time between parsing files. -
JavaParser
Instantiate the parser. Note that parsing can also be done with the static methodsStaticJavaParser
. Creating an instance will reduce setup time between parsing files.
-
-
Method Details
-
getParserConfiguration
- Returns:
- The configuration for this parser.
-
parse
Parses source code. It takes the source code from a Provider. The start indicates what can be found in the source code (compilation unit, block, import...)- Type Parameters:
N
- the subclass of Node that is the result of parsing in the start.- Parameters:
start
- refer to the constants in ParseStart to see what can be parsed.provider
- refer to Providers to see how you can read source. The provider will be closed after parsing.- Returns:
- the parse result, a collection of encountered problems, and some extra data.
-
parse
Parses the Java code contained in theInputStream
and returns aCompilationUnit
that represents it.- Parameters:
in
-InputStream
containing Java source code. It will be closed after parsing.encoding
- encoding of the source code- Returns:
- CompilationUnit representing the Java source code
- Throws:
ParseProblemException
- if the source code has parser errors
-
parse
- Parameters:
in
-InputStream
containing Java source code. It will be closed after parsing.- Returns:
- CompilationUnit representing the Java source code
- Throws:
ParseProblemException
- if the source code has parser errors
-
parse
@Deprecated public ParseResult<CompilationUnit> parse(File file, Charset encoding) throws FileNotFoundExceptionDeprecated.set the encoding in theParserConfiguration
Parses the Java code contained in aFile
and returns aCompilationUnit
that represents it.- Parameters:
file
-File
containing Java source code. It will be closed after parsing.encoding
- encoding of the source code- Returns:
- CompilationUnit representing the Java source code
- Throws:
ParseProblemException
- if the source code has parser errorsFileNotFoundException
- the file was not found
-
parse
- Parameters:
file
-File
containing Java source code. It will be closed after parsing.- Returns:
- CompilationUnit representing the Java source code
- Throws:
ParseProblemException
- if the source code has parser errorsFileNotFoundException
- the file was not found
-
parse
@Deprecated public ParseResult<CompilationUnit> parse(Path path, Charset encoding) throws IOExceptionDeprecated.set the encoding in theParserConfiguration
Parses the Java code contained in a file and returns aCompilationUnit
that represents it.- Parameters:
path
- path to a file containing Java source codeencoding
- encoding of the source code- Returns:
- CompilationUnit representing the Java source code
- Throws:
IOException
- the path could not be accessedParseProblemException
- if the source code has parser errors
-
parse
Parses the Java code contained in a file and returns aCompilationUnit
that represents it.- Parameters:
path
- path to a file containing Java source code- Returns:
- CompilationUnit representing the Java source code
- Throws:
ParseProblemException
- if the source code has parser errorsIOException
- the path could not be accessed
-
parseResource
Parses the Java code contained in a resource and returns aCompilationUnit
that represents it.- Parameters:
path
- path to a resource containing Java source code. As resource is accessed through a class loader, a leading "/" is not allowed in pathToResource- Returns:
- CompilationUnit representing the Java source code
- Throws:
ParseProblemException
- if the source code has parser errorsIOException
- the path could not be accessed
-
parseResource
@Deprecated public ParseResult<CompilationUnit> parseResource(String path, Charset encoding) throws IOExceptionDeprecated.set the encoding in theParserConfiguration
Parses the Java code contained in a resource and returns aCompilationUnit
that represents it.- Parameters:
path
- path to a resource containing Java source code. As resource is accessed through a class loader, a leading "/" is not allowed in pathToResourceencoding
- encoding of the source code- Returns:
- CompilationUnit representing the Java source code
- Throws:
ParseProblemException
- if the source code has parser errorsIOException
- the path could not be accessed
-
parseResource
@Deprecated public ParseResult<CompilationUnit> parseResource(ClassLoader classLoader, String path, Charset encoding) throws IOExceptionDeprecated.set the encoding in theParserConfiguration
Parses the Java code contained in a resource and returns aCompilationUnit
that represents it.- Parameters:
classLoader
- the classLoader that is asked to load the resourcepath
- path to a resource containing Java source code. As resource is accessed through a class loader, a leading "/" is not allowed in pathToResource- Returns:
- CompilationUnit representing the Java source code
- Throws:
ParseProblemException
- if the source code has parser errorsIOException
- the path could not be accessed
-
parse
Parses Java code from a Reader and returns aCompilationUnit
that represents it.- Parameters:
reader
- the reader containing Java source code. It will be closed after parsing.- Returns:
- CompilationUnit representing the Java source code
- Throws:
ParseProblemException
- if the source code has parser errors
-
parse
Parses the Java code contained in code and returns aCompilationUnit
that represents it.- Parameters:
code
- Java source code- Returns:
- CompilationUnit representing the Java source code
- Throws:
ParseProblemException
- if the source code has parser errors
-
parseBlock
- Parameters:
blockStatement
-String
containing Java block code- Returns:
- BlockStmt representing the Java block
- Throws:
ParseProblemException
- if the source code has parser errors
-
parseStatement
- Parameters:
statement
-String
containing Java statement code- Returns:
- Statement representing the Java statement
- Throws:
ParseProblemException
- if the source code has parser errors
-
parseImport
Parses the Java import contained in aString
and returns aImportDeclaration
that represents it.- Parameters:
importDeclaration
-String
containing Java import code- Returns:
- ImportDeclaration representing the Java import declaration
- Throws:
ParseProblemException
- if the source code has parser errors
-
parseExpression
Parses the Java expression contained in aString
and returns aExpression
that represents it.- Parameters:
expression
-String
containing Java expression- Returns:
- Expression representing the Java expression
- Throws:
ParseProblemException
- if the source code has parser errors
-
parseAnnotation
Parses the Java annotation contained in aString
and returns aAnnotationExpr
that represents it.- Parameters:
annotation
-String
containing Java annotation- Returns:
- AnnotationExpr representing the Java annotation
- Throws:
ParseProblemException
- if the source code has parser errors
-
parseAnnotationBodyDeclaration
Parses the Java annotation body declaration(e.g fields or methods) contained in aString
and returns aBodyDeclaration
that represents it.- Parameters:
body
-String
containing Java body declaration- Returns:
- BodyDeclaration representing the Java annotation
- Throws:
ParseProblemException
- if the source code has parser errors
-
parseBodyDeclaration
Parses a Java class or interface body declaration(e.g fields or methods) and returns aBodyDeclaration
that represents it.- Parameters:
body
- the body of a class or interface- Returns:
- BodyDeclaration representing the Java interface body
- Throws:
ParseProblemException
- if the source code has parser errors
-
parseClassOrInterfaceType
Parses a Java class or interface type name and returns aClassOrInterfaceType
that represents it.- Parameters:
type
- the type name like a.b.c.X or Y- Returns:
- ClassOrInterfaceType representing the type
- Throws:
ParseProblemException
- if the source code has parser errors
-
parseType
Parses a Java type name and returns aType
that represents it.- Parameters:
type
- the type name like a.b.c.X, Y, or int- Returns:
- ClassOrInterfaceType representing the type
- Throws:
ParseProblemException
- if the source code has parser errors
-
parseVariableDeclarationExpr
Parses a variable declaration expression and returns aVariableDeclarationExpr
that represents it.- Parameters:
declaration
- a variable declaration likeint x=2;
- Returns:
- VariableDeclarationExpr representing the type
- Throws:
ParseProblemException
- if the source code has parser errors
-
parseExplicitConstructorInvocationStmt
public ParseResult<ExplicitConstructorInvocationStmt> parseExplicitConstructorInvocationStmt(String statement)Parses the this(...) and super(...) statements that may occur at the start of a constructor.- Parameters:
statement
- a statement like super("hello");- Returns:
- the AST for the statement.
- Throws:
ParseProblemException
- if the source code has parser errors
-
parseName
Parses a qualified name (one that can have "."s in it) and returns it as a Name.- Parameters:
qualifiedName
- a name like "com.laamella.parameter_source"- Returns:
- the AST for the name
- Throws:
ParseProblemException
- if the source code has parser errors
-
parseSimpleName
Parses a simple name (one that can NOT have "."s in it) and returns it as a SimpleName.- Parameters:
name
- a name like "parameter_source"- Returns:
- the AST for the name
- Throws:
ParseProblemException
- if the source code has parser errors
-
parseParameter
Parses a single parameter (a type and a name) and returns it as a Parameter.- Parameters:
parameter
- a parameter like "int[] x"- Returns:
- the AST for the parameter
- Throws:
ParseProblemException
- if the source code has parser errors
-
parsePackageDeclaration
Parses a package declaration and returns it as a PackageDeclaration.- Parameters:
packageDeclaration
- a declaration like "package com.microsoft.java;"- Returns:
- the AST for the parameter
- Throws:
ParseProblemException
- if the source code has parser errors
-
parseTypeDeclaration
Parses a type declaration and returns it as a TypeDeclaration.- Parameters:
typeDeclaration
- a declaration like "class X {}"- Returns:
- the AST for the type declaration
- Throws:
ParseProblemException
- if the source code has parser errors
-
parseModuleDeclaration
Parses a module declaration and returns it as a ModuleDeclaration.- Parameters:
moduleDeclaration
- a declaration like "module X {}"- Returns:
- the AST for the module declaration
- Throws:
ParseProblemException
- if the source code has parser errors- See Also:
ModuleDeclaration
-
parseModuleDirective
Parses a module directive and returns it as a ModuleDirective.- Parameters:
moduleDirective
- a directive like "opens C;"- Returns:
- the AST for the module directive
- Throws:
ParseProblemException
- if the source code has parser errors- See Also:
ModuleDirective
-
parseTypeParameter
Parses a type parameter and returns it as a TypeParameter- Parameters:
typeParameter
- a parameter like "T extends Serializable"- Returns:
- the AST for the type parameter
- Throws:
ParseProblemException
- if the source code has parser errors
-
parseMethodDeclaration
Parses a method declaration and returns it as a MethodDeclaration.- Parameters:
methodDeclaration
- a method declaration like "void foo() {}"- Returns:
- the AST for the method declaration
- Throws:
ParseProblemException
- if the source code has parser errors- See Also:
MethodDeclaration
-
ParserConfiguration