| Nicholas Smith | 646793d | 2015-01-20 14:53:07 +0000 | [diff] [blame] | 1 | ## Java Parser and Abstract Syntax Tree
|
| matozoid | 2cab70d | 2013-09-16 13:31:33 +0200 | [diff] [blame] | 2 |
|
| Danny van Bruggen | 3ad0750 | 2017-03-23 15:24:33 +0100 | [diff] [blame] | 3 | This package contains a Java 1.0 - Java 9 Parser with AST generation and visitor support.
|
| Nicholas Smith | cd1296d | 2015-01-20 14:22:40 +0000 | [diff] [blame] | 4 |
|
| Danny van Bruggen | 1188750 | 2016-12-05 19:27:34 +0100 | [diff] [blame] | 5 | The AST records the source code structure.
|
| 6 | You can analyze source code for any purpose.
|
| 7 | It is possible to change the AST nodes or create new ones to modify the source code.
|
| 8 |
|
| 9 | When you need not only the text from the source code but you also need type information,
|
| 10 | you can use [the Java Symbol Solver project.](https://github.com/javaparser/javasymbolsolver)
|
| matozoid | 2d4deca | 2011-10-30 14:35:59 +0100 | [diff] [blame] | 11 |
|
| Nicholas Smith | d7c5113 | 2015-09-02 13:14:42 +0100 | [diff] [blame] | 12 | [](http://search.maven.org/#search%7Cgav%7C1%7Cg%3A%22com.github.javaparser%22%20AND%20a%3A%22javaparser-core%22)
|
| Nicholas Smith | 2b77f43 | 2015-02-23 11:01:28 +0000 | [diff] [blame] | 13 | [](https://travis-ci.org/javaparser/javaparser)
|
| Nicholas Smith | cc80fc1 | 2015-08-17 15:15:26 +0100 | [diff] [blame] | 14 | [](https://coveralls.io/github/javaparser/javaparser?branch=master)
|
| Nicholas Smith | d6a8098 | 2015-08-17 15:25:32 +0100 | [diff] [blame] | 15 | [](https://gitter.im/javaparser/javaparser?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
|
| Nicholas Smith | cc80fc1 | 2015-08-17 15:15:26 +0100 | [diff] [blame] | 16 |
|
| Nicholas Smith | cd1296d | 2015-01-20 14:22:40 +0000 | [diff] [blame] | 17 | ## Features
|
| 18 |
|
| 19 | * Light weight
|
| 20 | * Performant
|
| 21 | * Easy to use
|
| 22 | * Modifiable AST
|
| Danny van Bruggen | 1188750 | 2016-12-05 19:27:34 +0100 | [diff] [blame] | 23 | * Code generation
|
| Nicholas Smith | cd1296d | 2015-01-20 14:22:40 +0000 | [diff] [blame] | 24 | * Support of comments
|
| 25 |
|
| 26 | ## Dependency Management
|
| 27 |
|
| matozoid | 3c137e9 | 2016-04-06 19:37:37 +0200 | [diff] [blame] | 28 | The project binaries are available in Maven Central. Just add the following to your maven configuration or tailor to your own dependency management system.
|
| Federico Tomassetti | cf8d7b1 | 2014-07-30 19:00:26 +0100 | [diff] [blame] | 29 |
|
| Danny van Bruggen | eb24896 | 2017-01-11 15:00:00 +0100 | [diff] [blame] | 30 | [Please refer to the Migration Guide when upgrading from 2.5.1](https://github.com/javaparser/javaparser/wiki/Migration-Guide)
|
| Parth Mehrotra | 112f459 | 2017-07-10 13:47:53 -0400 | [diff] [blame] | 31 |
|
| 32 | For Maven:
|
| 33 |
|
| Danny van Bruggen | 1188750 | 2016-12-05 19:27:34 +0100 | [diff] [blame] | 34 | ```xml
|
| 35 | <dependency>
|
| 36 | <groupId>com.github.javaparser</groupId>
|
| 37 | <artifactId>javaparser-core</artifactId>
|
| Danny van Bruggen | 969b7f6 | 2017-07-10 21:03:41 +0200 | [diff] [blame] | 38 | <version>3.2.11</version>
|
| Danny van Bruggen | 3588d26 | 2017-02-19 23:00:47 +0100 | [diff] [blame] | 39 | </dependency>
|
| 40 | ```
|
| 41 |
|
| Parth Mehrotra | 112f459 | 2017-07-10 13:47:53 -0400 | [diff] [blame] | 42 | For Gradle:
|
| 43 |
|
| 44 | ```
|
| Danny van Bruggen | 969b7f6 | 2017-07-10 21:03:41 +0200 | [diff] [blame] | 45 | compile 'com.github.javaparser:javaparser-core:3.2.11'
|
| Parth Mehrotra | 112f459 | 2017-07-10 13:47:53 -0400 | [diff] [blame] | 46 | ```
|
| 47 |
|
| Nicholas Smith | cd1296d | 2015-01-20 14:22:40 +0000 | [diff] [blame] | 48 | ## How To Compile Sources
|
| Nicholas Smith | 15a23ae | 2015-01-14 10:27:51 +0000 | [diff] [blame] | 49 |
|
| Danny van Bruggen | d67b506 | 2017-04-16 15:07:23 +0200 | [diff] [blame] | 50 | If you checked out the project from GitHub you can build the project with maven using:
|
| Federico Tomassetti | cf8d7b1 | 2014-07-30 19:00:26 +0100 | [diff] [blame] | 51 |
|
| Federico Tomassetti | 2051f04 | 2014-07-30 19:01:19 +0100 | [diff] [blame] | 52 | ```
|
| Federico Tomassetti | cf8d7b1 | 2014-07-30 19:00:26 +0100 | [diff] [blame] | 53 | mvn clean install
|
| Federico Tomassetti | 2051f04 | 2014-07-30 19:01:19 +0100 | [diff] [blame] | 54 | ```
|
| Federico Tomassetti | cf8d7b1 | 2014-07-30 19:00:26 +0100 | [diff] [blame] | 55 |
|
| Danny van Bruggen | 1188750 | 2016-12-05 19:27:34 +0100 | [diff] [blame] | 56 | If you checkout the sources and want to view the project in an IDE, it is best to first generate some of the source files; otherwise you will get many compilation complaints in the IDE. (mvn clean install already does this for you.)
|
| Nicholas Smith | cd1296d | 2015-01-20 14:22:40 +0000 | [diff] [blame] | 57 |
|
| 58 | ```
|
| 59 | mvn javacc:javacc
|
| 60 | ```
|
| 61 |
|
| Danny van Bruggen | 45f8318 | 2017-07-10 20:15:11 +0200 | [diff] [blame] | 62 | If you modify the code of the AST nodes, specifically if you add or remove fields or node classes,
|
| Danny van Bruggen | 969b7f6 | 2017-07-10 21:03:41 +0200 | [diff] [blame] | 63 | the code generators will update a lot of code for you.
|
| Danny van Bruggen | 45f8318 | 2017-07-10 20:15:11 +0200 | [diff] [blame] | 64 | The `run_metamodel_generator.sh` script will rebuild the metamodel,
|
| 65 | which is used by the code generators which are run by `run_core_generators.sh`
|
| 66 | Make sure that `javaparser-core` at least compiles before you run these.
|
| 67 |
|
| Nicholas Smith | cd1296d | 2015-01-20 14:22:40 +0000 | [diff] [blame] | 68 | ## Manual
|
| 69 |
|
| 70 | Examples of how to use the library can be found on the [Manual](https://github.com/javaparser/javaparser/wiki/Manual) page of the wiki
|
| 71 |
|
| Nicholas Smith | 26c753d | 2015-01-14 10:02:55 +0000 | [diff] [blame] | 72 | ## Troubleshooting
|
| 73 |
|
| Danny van Bruggen | 1188750 | 2016-12-05 19:27:34 +0100 | [diff] [blame] | 74 | First try the [wiki](https://github.com/javaparser/javaparser/wiki).
|
| Nicholas Smith | 26c753d | 2015-01-14 10:02:55 +0000 | [diff] [blame] | 75 |
|
| Danny van Bruggen | 1188750 | 2016-12-05 19:27:34 +0100 | [diff] [blame] | 76 | Didn't find an answer? Try [searching for existing issues](https://github.com/javaparser/javaparser/issues?utf8=%E2%9C%93&q=is%3Aissue%20)
|
| 77 |
|
| 78 | Still nothing? [Open an issue](https://github.com/javaparser/javaparser/issues/new) or [come chat on Gitter](https://gitter.im/javaparser/javaparser)
|
| Federico Tomassetti | cf8d7b1 | 2014-07-30 19:00:26 +0100 | [diff] [blame] | 79 |
|
| 80 | ## Javadoc
|
| 81 |
|
| Nicholas Smith | c86a9ff | 2015-08-12 13:20:26 +0100 | [diff] [blame] | 82 | The libraries javadoc can be found [here](http://www.javadoc.io/doc/com.github.javaparser/javaparser-core/)
|
| Federico Tomassetti | cf8d7b1 | 2014-07-30 19:00:26 +0100 | [diff] [blame] | 83 |
|
| 84 | ## History
|
| 85 |
|
| Didier Villevalois | d5e8843 | 2015-03-16 14:23:45 +0100 | [diff] [blame] | 86 | This parser is based on work by Sreenivasa Viswanadha and JĂșlio Vilmar Gesser. The original project, now inactive, was originally hosted at [Google Code](http://code.google.com/p/javaparser/) and supported only parsing Java 1.5.
|
| matozoid | 2d4deca | 2011-10-30 14:35:59 +0100 | [diff] [blame] | 87 |
|
| Danny van Bruggen | 3ad0750 | 2017-03-23 15:24:33 +0100 | [diff] [blame] | 88 | The project now supports parsing Java 9 and aims to continue support for features in future versions of the Java language.
|
| Nicholas Smith | 26c753d | 2015-01-14 10:02:55 +0000 | [diff] [blame] | 89 |
|
| Federico Tomassetti | 43e1e41 | 2015-08-06 17:31:26 +0200 | [diff] [blame] | 90 | ## Related projects
|
| 91 |
|
| Federico Tomassetti | 212fd3f | 2016-10-20 21:41:35 +0200 | [diff] [blame] | 92 | [JavaSymbolSolver](https://github.com/javaparser/javasymbolsolver) is a project from the same committers working on JavaParser.
|
| 93 | You can use it to calculate the type of JavaParser expressions and connecting references with their declarations.
|
| 94 |
|
| Federico Tomassetti | 43e1e41 | 2015-08-06 17:31:26 +0200 | [diff] [blame] | 95 | From JavaParser other projects have been derived:
|
| 96 |
|
| 97 | * [Walkmod](http://walkmod.com/): a tool to automatically correct violations of code conventions
|
| Edgar Espina | 1986cf8 | 2016-02-29 09:40:38 -0300 | [diff] [blame] | 98 | * [jooby spec](http://jooby.org/doc/spec): analyze and exports [jooby routes](http://jooby.org) to [raml](http://raml.org) and [Swagger](http://swagger.io)
|
| Federico Tomassetti | 43e1e41 | 2015-08-06 17:31:26 +0200 | [diff] [blame] | 99 |
|
| 100 | ## Credits
|
| 101 |
|
| 102 | This project has been maintained thanks to the joint efforts of many contributors: we are extremely grateful to all of them.
|
| 103 |
|
| 104 | In particular we are thankful to the contributions we received by the [Walkmod](http://walkmod.com/) project which permitted to finalize support for Java 8. The author granted us the permissions to release that code also under the Apache License and we have greatly appreciated that.
|
| 105 |
|
| Didier Villevalois | d5e8843 | 2015-03-16 14:23:45 +0100 | [diff] [blame] | 106 | ## License
|
| Nicholas Smith | 26c753d | 2015-01-14 10:02:55 +0000 | [diff] [blame] | 107 |
|
| Federico Tomassetti | 2c7ba12 | 2015-08-12 08:06:33 +0200 | [diff] [blame] | 108 | JavaParser is available either under the terms of the LGPL License or the Apache License. You as the user are entitled to choose the terms under which adopt JavaParser.
|
| Federico Tomassetti | ee6a48a | 2015-07-25 14:42:17 +0200 | [diff] [blame] | 109 |
|
| 110 | For details about the LGPL License please refer to [LICENSE.LGPL](ttps://github.com/javaparser/javaparser/blob/master/LICENSE.LGPL).
|
| 111 |
|
| 112 | For details about the Apache License please refer to [LICENSE.APACHE](ttps://github.com/javaparser/javaparser/blob/master/LICENSE.APACHE).
|