- The funny "PI" version number messed up the release order in the maven site, so here is a new minor release. issues resolved
- BREAKING:
NodeWithConstructors
has been merged intoNodeWithMembers
, so if you don't have a very specific need to only find nodes that support constructors, you can useNodeWithMembers
instead.
- BREAKING: the pseudo-language levels have been turned into constants with the same name in the same place. With a little luck everything will keep compiling.
- BREAKING: Java 13:
break
no longer has an expression, this was part of a language preview in Java 12 and has been removed in Java 13. - BREAKING: Java 13:
YieldStatement
and the keywordyield
have been added. This means the token numbers have changed, and this affects serialization. If you rely on serialized tokens, be sure to deserialize with your current version and serialize with this version. - Java 13:
TextBlockLiteralExpr
has been added. - This release is broken because no identifier called
yield
can be used.
- BREAKING:
SuperExpr
andThisExpr
used to have anExpression classExpr
. this has been tightened toName typeName
which is more specific and easier to use. Checking if the expression is aFieldAccessExpr
orNameExpr
is no longer needed.
(release failed)
- "BREAKING":
ReferenceType.getDirectAncestors()
no longer returnsjava.lang.Object
when called on aReferenceType
ofjava.lang.Object
. This remedies infinite recursions in certain edge cases. If you relied on the old behavior, you have to add aReferenceType
instance ofjava.lang.Object
to the List returned byReferenceType.getDirectAncestors()
yourself.
- Version 3.13.0 and 3.13.1 contain rather bad bugs that have been fixed here.
- Slightly breaking: most parameters to Log methods now take consumers to avoid evaluating them when not necessary.
- "BREAKING": The static
JavaParser.parse...
methods have moved toStaticJavaParser.parse...
!
- "BREAKING": all deprecated code was removed. If you don't know what to do, try version 3.11.0 and read the Javadoc for the deprecated methods. It tells you what to use instead.
- BREAKING:
SwitchEntryStmt
is nowSwitchEntry
, because it was never a statement. - BREAKING: a case in a switch can now have multiple labels,
so
SwitchEntry
no longer has anExpression label
, but aNodeList<Expression> label
. - This completes parsing support for Java 12. Symbol resolution is still to be done.
- slightly breaking: besides
break;
andbreak [label];
there is nowbreak [expression];
likebreak 1+2;
orbreak "bye!";
. That means thatBreakStmt
no longer has alabel
, it has avalue
which is of typeExpression
. This is to prepare for Java 12 switch expressions. You can find the details in the Javadoc.
- MAJOR BREAKAGE: modifiers (like public, static, transient) used to be a special case:
they were enums stored in an EnumSet.
This meant they were not true
Node
s, had to be treated in a special way, and missed some information. This has now been corrected in PR 1975.
- slightly breaking:
ObjectCreationExpr
no longer gets a diamond when constructed with the default constructor.
- A Unicode preprocessing filter is now available again.
- slightly breaking: the enum constants in JsonToken are now capitalized.
- slightly breaking: some obscure methods in the symbol solver changed
- BREAKING:
ForeachStmt
is now correctly capitalized:ForEachStmt
- BREAKING: when using modules, everything that was called
...Statement
is now correctly called...Directive
- The Json serialization now serializes more fields, which should not impact existing code.
- BREAKING: Node.getData now throws an exception if the data was not set before. This can be rewritten by checking with Node.containsData before doing getData.
findAncestor(type, predicate)
is now available
- Parsing Java 11 is now supported.
- Running on Java 11 is now supported.
- Building on JDK 11 is NOT yet supported.
- A new artifact was added: javaparser-core-serialization. It contains a JSON serializer, and might get more serializers in the future.
- BREAKING: some parts of the module syntax used
Type
where they should have usedName
. This is now fixed, but your code may need to be adapted if you are parsing modules.
- JavaParserFacade.getType now can also handle NameExpr referring to types while before they were not supported. See issue #1491
- A mixup during the release put all the issues in the same milestone:
- Intellij Idea project files were deleted from the repository, so if you have a clone of the JP source, your local files will be deleted as well. Save anything you want to keep.
- You can now configure the parser inside JavaParserTypeSolver.
- Be aware of annotations or indents looking slightly different when output!
- BREAKING:
SymbolSolverQuickSetup
has been removed in favor ofProjectRoot
andSymbolSolverCollectionStrategy
.
- @daanschipper added
ProjectRoot
which is used for analysing and storing project structure. - Upgraded version from 3.5.20 to 3.6.0 because people got tired of seeing 3.5.
- Thanks to @daanschipper for the PR :-)
- Java 10 support is complete.
- BREAKING: Java language level support has changed to make Java 10 support possible. Here's a little article about it
- Java 10's
var
can now be parsed and will be turned into aVarType
node. It can not be resolved yet. NodeList
now has a pretty complete set of...First
and...Last
methods. Thanks stephenramthun !
- The Javadoc parser has received a lot of attention.
- Thanks to un0btanium for fixing the readme file!
- BREAKING:
AssignExpr.Operator.AND
is nowAssignExpr.Operator.BINARY_AND
. - BREAKING:
AssignExpr.Operator.OR
is nowAssignExpr.Operator.BINARY_OR
. getPrimaryTypeName
andgetPrimaryType
give access to the type that has the same name as the file it came from.- Enums will now get their constants aligned vertically if there are more than five.
- You can now convert between
AssignExpr.Operator
andAssignExpr.Operator
if you like.
- JavaSymbolSolver is now in the same project as JavaParser, meaning they get released together from now on.
- LexicalPreservingPrinter has had a big speed optimization.
- BREAKING: the very confusing constructor
NodeList(Node)
(which sets the parent) was removed. - To avoid using the int type for token kinds, use the new
JavaToken.Kind
enum. It can convert to and from the int kind.
- the module name is now set to com.github.javaparser.core
toSomeType()
methods have been added for many types that give more functional access to a subtype.- BETA: the below work on Java Symbol Solver is still ongoing.
- SourceRoot is now silent by default - look at the Log class if you want to change that.
- BETA: the below work on Java Symbol Solver is still ongoing.
- BETA: the below work on Java Symbol Solver is still ongoing.
- Unicode escapes (
\u1234
) are now retained in the AST, but they are now only allowed in comments, string and character literals, and identifiers. - BETA: the below work on Java Symbol Solver is still ongoing.
- The pretty printer now cleans up Javadoc comments.
- BETA: the below work on Java Symbol Solver is still ongoing.
- BETA: the below work on Java Symbol Solver is still ongoing.
- A functional visitor API has been added. See PR 1195 for now.
- Build is working again on Windows thanks to Leonardo Herrera.
- The pretty printer now has an option to order imports, also thanks to Leonardo Herrera.
- Receiver parameters are now well-supported instead of being a hack. See issue 1194 for a description.
- BETA: the below work on Java Symbol Solver is still ongoing.
- BETA: the below work on Java Symbol Solver is still ongoing.
- BETA: we're still doing work to integrate parts of Java Symbol Solver to simplify its API.
VisitorMap
is joined byVisitorSet
andVisitorList
, for when you want to storeNode
s in collection but don't want its default equals/hascode behaviour
- BETA: we're doing work to integrate parts of Java Symbol Solver to simplify its API.
- JDK 9 will compile JavaParser now.
- An official sample Maven setup was added.
- Two visitors were added:
NoCommentEqualsVisitor
andNoCommentHashCodeVisitor
- as the name implies you can use these to compare nodes without considering comments. Thanks Ryan Beckett! isSomeType()
methods have been added for many types that help avoidinstanceof
.asSomeType()
methods have been added for many types that help avoid casting to that type.ifSomeType()
methods have been added for many types, giving a nice functional way of doing if-is-type-then-cast-to-type-then-use.- The
LexicalPreservingPrinter
had its API changed a little: setup and printing are now separate things, so you don't have to drag an instance ofLexicalPreservingPrinter
through your code anymore. traverseScope
was added to all nodes with a scope, so you can travel through the scope without tripping over (non-)optionality.
- BREAKING: We missed a Java 9 feature which is now on board: try with resources can now refer to a resource declared outside of the statement.
This means that the node type you get for those resources is now
Expression
instead ofVariableDeclarationExpr
. For Java 8 and below you can simply cast it toVariableDeclarationExpr
again. See also the Javadoc forTryStmt
. - You can now inspect the AST by exporting it to XML, JSON, YAML, or a Graphviz's dot diagram, thanks to Ryan Beckett!
GenericVisitorWithDefaults
andVoidVisitorWithDefaults
were added which function like empty visitors, but all the visit methods call a default method by default.- Annotation support was cleaned up, adding some obscure locations where you can have annotations.
EnumDeclaration
regained its constructor builder methods. They were accidentally lost around 3.2.2.ArrayType
now has anorigin
field which indicates in which position the array brackets were found.
SourceZip
has been added. Use it to read source code from jars or zip files. Thank you @ryan-beckett !- JavaCC was upgraded to 7.0.2
- A new option for the pretty printer was added. You can now wrap-and-column-align parameters of method calls. Thank you @tarilabs !
- Parsing a partial java file (like an expression or statement) no longer ignores trailing code.
- New memory saving option: turn off token list.
VisitorMap
lets you override hashcode/equals for nodes when used as a key for a map.
- The token list is now mutable - see methods on
JavaToken
. This caused mild breakage - some fields have becomeOptional
.
- Breaking:
TryStmt::tryBlock
andEnclosedExpr::inner
were optional for no good reason. Now they are required. - You can now ask a
JavaToken
for its category, which is useful for examining the token list or doing syntax highlighting or so. enum
andstrictfp
can now be used as identifiers on lower Java versions.
- We're up to date with the latest Java 9 module system again.
Node.replace(old, new)
was added, including property-specificX.replaceY(newY)
methods
Scrapped due to release problem.
- Added
isInnerClass()
that checks if aClassOrInterfaceDeclaration
is an inner class (note: this is different from a nested class!) - @ryan-beckett contributed a huge Eclipse setup guide
- We now recover from some parse errors! Here is an article
EmptyMemberDeclaration
is gone! It was deprecated for a while because it it was in the AST, but doesn't have any meaning in a Java program.EmptyStmt
was also deprecated, but that has been reverted. This node does have meaning.
NodeWithCondition
was added on all nodes containing a condition.- Lots of work on improving lexical preservation.
- If a file was parsed from a file system, you can now get path information etc. from
CompilationUnit
- API BREAKING: every node now points to its start and end token.
Some of the API has started returning
TokenRange
instead ofRange
- you can calltoRange
to get the old object type. We may still change the naming of some of this code in the following month.
New style changelog, no more issue numbers, but a link: issues resolved and any notable changes:
- the new method
Node.removeForced()
by removing it, or removing the first parent that is optional. This is different fromNode.remove()
,remove()
only tries to remove the node from the parent and fails if it can't. FieldAccessExpr.scope
is now a required property. You might find someget()
s in your code that are no longer necessary.ReferenceType
no longer has a type parameter, so everyReferenceType<?>
can be replaced byReferenceType
now.
- 907 906 905 903 911 910 909 908 smaller improvements and fixes
Beta: TreeStructureVisitor
.
- 770 902 904 901 smaller improvements and fixes
Beta: TreeStructureVisitor
.
- Maven dependencies were updated to their latest versions
- 890 the concept of "method signature" now exists in JavaParser
- 896 891 889 887 882 789 smaller improvements and fixes
The lexical preservation code is stable!
Beta: TreeStructureVisitor
.
- 885 884 879 878 smaller improvements and fixes
This is the first version to parse Java 9.
Beta: TreeStructureVisitor
, and LexicalPreservingPrinter
.
- 872 873 874 787 Remaining Java 9 work.
Beta: TreeStructureVisitor
, and LexicalPreservingPrinter
.
A start has been made on source level support. The default level is Java 8. It can be set to Java 9 like this for a parser instance:
private final JavaParser parser = new JavaParser(new ParserConfiguration().setValidator(new Java9Validator()));
and like this for the static parse methods:
QuickJavaParser.getConfiguration().setValidator(new Java9Validator());
- 862 552 "_" is an illegal identifier on source level 9.
- 869 867 109 855 857 smaller improvements and fixes
Beta: TreeStructureVisitor
, ConcreteSyntaxModel
, and LexicalPreservingPrinter
.
- 594 849 831 a validation framework was introduced to inform about problems in the AST without needing to change the grammar, and without requiring parsing code. It is open for extension by users.
- 852 853 826 832 846 839 smaller improvements and fixes
Beta: TreeStructureVisitor
, ConcreteSyntaxModel
, and LexicalPreservingPrinter
.
- 654 124 lexical preservation (printing source code with the same formatting it had when parsing) has been added. Thank you @ftomassetti for a lot of work!
- 554 800 first (big) step towards Java 9 support: JavaParser can read project Jigsaw module definitions.
- 795 786 751 extend the TreeVisitor with more traversal options. Thanks @ryan-beckett!
- 791
GenericListVisitorAdapter
has been added which collects its results in a list. Thanks @Gottox! - 815 798 797 813 clean up Problem text
- 819 818 817 816 441 809 808 807 fix various absurd annotation related issues.
- 777 805 802 796 790 792 793 781 784 785 783 782 779 357 799 763 smaller improvements and fixes
Beta: TreeStructureVisitor
and ConcreteSyntaxModel
.
-
705 755 Add the concrete syntax model, which will give you information about the exact syntax a certain nodes matches.
-
777 smaller improvements and fixes
This version is a beta because TreeStructureVisitor
is not in its definite state yet.
- 762 761 772 merge
javaparser-metamodel
andjavaparser-generator-utils
intojavaparser-core
. - 766 the
ModifierVisitor
is now created by a code generator. Its behaviour has been made logical, and may give different results than before. - 755
ConstructorDeclaration
andMethodDeclaration
now share a parent:CallableDeclaration
- 687 759 773 769 768 767 765 759 smaller improvements and fixes
This version is a beta because there are a lot of new features that may still change.
This version needs a minor version increase because of a backwards compatability issue:
- 719
getJavadoc
,getJavadocComment
andgetComment
could return null. Our promise was to returnOptional
, so that is what they do now.
New:
- 658 718 736 737 we have created a metamodel.
It gives information about the structure of the various AST nodes, as if you are introspecting them.
You can find it in
javaparser-metamodel
, the main class isJavaParserMetaModel
- 353 365 visitors are no longer hand made, they are now generated from the metamodel. This should make them 100% reliable.
Affected visitors are:
GenericVisitorAdapter
,EqualsVisitor
,VoidVisitorAdapter
,VoidVisitor
,GenericVisitor
,HashCodeVisitor
,CloneVisitor
.
If you want to generate your own visitors, you can use the VisitorGenerator
class from javaparser-core-generators
If you want to reuse the code generation utilities, look at module javaparser-generator-utils
- there is a very useful SourceRoot
class in there that takes away a lot of file management troubles.
- 538 735
TreeStructureVisitor
has been added, which should be considered beta. - 220 733 717 749 745 750 743 748 666 732 746 734 733 smaller improvements and fixes
- 699 433 325 Javadoc can now be parsed
- 703 696 added NodeWithOptionalScope
- 702 FieldAccessExpr now implements NodeWithSimpleName, which means that "field" has been renamed to "name"
- 707 706 improve range of array types and levels
- 709 smaller improvements and fixes
- 695 697 689 680 693 691 682 690 677 679 688 684 683 smaller improvements and fixes
- 668 669 TypeDeclarationStmt became LocalClassDeclarationStmt
- 347 665 every node now has some documentation
- 660 670 673 four types of import declaration have been merged back into the old ImportDeclaration
- 659 The pretty printer can now take customized visitors
- 650 671 672 674 524 smaller improvements and fixes
- 639 622 632 657 656 652 653 647 648 645 194 643 630 624 628 627 626 625 623 cleanups, small fixes, and general housekeeping
- 593 EmptyImportDeclaration and NonEmptyImportDeclaration have been removed
- 612 VariableDeclaratorId has been removed. It has been substituted by "SimpleName name"
- 614 617 the list of tokens has been linearized and simplified
- 615 support for arrays has once more been changed. See the issue
- 580 453 380 618 580 611 610 424 608 smaller improvements and fixes
- 499 601 renames many fields to be more consistent
- 596 605 602 604 smaller improvements and fixes
- 547 595 Node.range is now using Optional instead of Range.UNKNOWN
- 584 588 548 585 bug fixes and improvements
- 578 579 577 575 290 570 568 567 562 564 551 bug fixes and improvements
- 403 358 549 Make all names nodes: either SimpleName or Name. This makes every name in the AST visitable. NameExpr is now a wrapper to use SimpleName in an expression.
- 516 536 use Optional<> for return values.
- 556 557 558 550 small improvements and fixes.
- 560 559 make nodes observable.
- 344 529 turn DumpVisitor into an official PrettyPrinter
- 532 508 427 530 531 513 528 cleanups
- 515 roll back attempt at using Optional
- 522 504 make NodeList not a Node (restores parent/children behaviour to before alpha.4)
- 527 526 rename getChildrenNodes to getChildNodes
- 525 495 520 bug fix
- 503 modified ImportDeclaration hierarchy to have getters for static and "asterisk" again
- 506 bug fix
- 451 null is no longer allowed in the AST. See last post in issue
- 501 421 420 316 use a special type of list for nodes: NodeList. See last post in issue
- 463 471 nodes can now be removed easily
- 491 import handling changed. Instead of "ImportDeclaration", we now have the four types of import as described in the JLS. See issue
- 452 355 474 494 various improvements
- 493 492 485 Simplify the JavaParser interface
- 112 237 466 465 461 460 458 457 fundamentally changes how we deal with arrays. It is explained in the last post here
- 472 456 makes the "data" field on every node more structured.
- 477 468 refactor TypeArguments. You will find that TypeArguments is no longer a type, it is just a list in some nodes.
- 482 adds the "nodeTypes" packages to the osgi export.
- 479 476 makes all setters on nodes return this so they become chainable.
- 473 437 clean up CloneVisitor.
- 157 a new parser frontend, check javaparser#447 for explanations
- 435 more builder methods like 400 and 405
- 111 440 443 444 445 446 bugs & cleanups
- 400 405 introduce many "builder" style methods for constructing code. Thanks DeepSnowNeeL!
- 409 remove ASTHelper (methods are now on specific Node subclasses)
- 414 JavaParser can now be instantiated and reused. InstanceJavaParser removed
- 418 417 411 408 bugs
- 367 420 407 402 various cleanups
- 394 OSGi manifest added
- 391 fix ModifierVisitor NullPointerException bug
- 385 a few new parse methods
- 386 fix dumping an empty import (a single ; after the package declaration)
API breaking changes:
-
191: moved TreeVisitor to visitor package
-
368, 162, 303, 302, 360: use correct type in some places.
-
371: code is now compiled with Java 8
-
342, 331: ModifierVisitorAdapter detects and removes broken nodes
-
328, 270: upgrade JavaCC (use TokenMgrException now) Other changes:
-
297: enable access to tokens.
-
341, 361: node positions are now OO
-
211, 373: escaping of \n \r for string literals
-
336, 276, 141: JavaDoc support now works
-
337, 281: reorganize the stream reading code
-
343, 309, 332, 57: take advantage of common interfaces
-
329, 326, 327: deal with platform issues
-
163, 236, 252, 296, 269, 339, 321, 322, 252, 253, 293, 295: various fixes
-
310, 311, 313, 301, 294: some code clean-ups
- several fixes in DumpVisitor for bugs due to lazy initialization
- make TypeDeclaration implements DocumentableNode directly
- TypedNode interface introduced
- introduce MultiBoundType
- refactored IntersectionType and UnionType
- refactored CatchClause
- parsing annotations in throws declarations
- parse orphan semicolons in import statements
- added PackageDeclaration.getPackageName
- solved issue with newlines in string literals
- fixed handling of UnknownType in EqualsVisitor
- improvements to CommentsParser
- removing old grammar
- ClassOrInterfaceType implements NamedNode
- DumpVisitor can now be extended
- Improved documentation
- AST: lists are now lazy initialized
- Features
- Bugfixes
- #79 Fix NPE in
ConstructorDeclaration.getDeclarationAsString
- #86 Add missing functions to ModifierVisitorAdapter
- #82 set LambdaExpr as parent of its child nodes
- #87 implement
setJavadoc
andgetJavadoc
at various classes - #96 Fixed encoding issue in
Javaparser.parse
- #85 Casting a lambda expression causes a parsing failure
- #88
MethodReferenceExpr
andTypeExpr
don't set themselves as parents
- #79 Fix NPE in
- Internal
- support Java 8
- Fixed issues:
- Issue 17: A refactor suggestion for AnnotationExpr and its subclasses
- Issue 21: Java 5 JavaParser compiled JARs
- Issue 22: Please use java.lang.reflect.Modifier constants in japa.parser.ast.body.ModifierSet
- Issue 27: Implement the "equal" method
- Issue 30: equals and hashCode methods
- Issue 19 fixed:
- Tests changed to run with junit 4
- Issue 11 fixed: changed method get/setPakage to get/setPackage in the class CompilationUnit
- Created new visitor adapter to help AST modification: ModifierVisitorAdapter
- Changed visitor adapters to abstract
- Created simplified constructors in the nodes of the AST (without positional arguments)
- Created ASTHelper class with some helpful methods (more methods are still needed)
- Moved to javacc 4.1.
- The java_1_5.jj can be build alone without compilation errors
- Removed SuperMemberAccessExpr class, it was no longer used
- Removed the methods get/setTypeArgs() from ArrayCreationExpr, this node shouldn't have these methods.
- Fixed the bug with start/end position of the nodes IntegerLiteralMinValueExpr and LongLiteralMinValueExpr
- The methods get/setAnnotations() from all BodyDeclaration subclasses were pushed down to BodyDeclaration class
- Issue fixed: Issue 1: Add support for editing AST nodes or create new ones
- Issue fixed: Issue 5: end line and end column equal to begin line and begin column
- Changed version numbering, starting version 1.0.0
- Javadoc done for packages:
- japa.parser
- japa.parser.ast
- Corrected bug when parsing in multithread:
- JavaParser.setCacheParser(false) must be called before to use the parser concurrent
- No code changes, added binary distribution to download page
- Bug corrected: NPE in VoidVisitorAdapter
- Added Adapters for de visitors
- This project now is published at Google Code:
- Added support for comments and javadoc to the tree.
- Javadocs are stored directly to members (BodyDeclaration and all deriveds (classes, methods, fields, etc.)), accessible by the method getJavadoc().
- All comments are stored in the CompilationUnit, accessible by the method getComments().
- Changed all nodes public attributes to be private and created getters to access them
- Changed the methods of the Node getLine e getColumn to getBeginLine and getBeginColumn
- Added the methods getEndLine and getEndColumn to the Node class (works only in the BlockNode)
- Corrected ConditionalExpression bug
- Added LGPL License
- Bugs corrected:
- Created PackageDeclaration member of CompilationUnit to add suport for annotations in the package declaration
- Parameterized anonymous constructor invocation
- Explicit constructor invotation Type Arguments
- ctrl+z ("\u001A") ar end of compilation unit
- EnumConstantDeclaration annotation support corrected
- Parssing Java Unicode escape characters suport added
- Bug corrected: "MotifComboPopup.this.super()" statement was generating parser error
- Bug corrected: Casting signed primitive values
double d = (double) -1;
^
- Bug with the single line comments in the final of the unit corrected
- Fixed the bug with the following expression:
Class c = (int.class);
- Bug fixes from Leon Poyyayil work
- suport for hex floating point
- unicode digits in indentifier
- MemberValueArrayInitializer
- Long and Integer literal MIN_VALUE bug
- '\0' bug fixed
- Many bug fixes
- Added line/column to nodes