| 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 |
|
| Nicholas Smith | 26c753d | 2015-01-14 10:02:55 +0000 | [diff] [blame] | 3 | This package contains a Java 1.8 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 | 1188750 | 2016-12-05 19:27:34 +0100 | [diff] [blame^] | 30 | Suggested version (many fixes, new features, and mostly stable API):
|
| 31 | ```xml
|
| 32 | <dependency>
|
| 33 | <groupId>com.github.javaparser</groupId>
|
| 34 | <artifactId>javaparser-core</artifactId>
|
| 35 | <version>3.0.0-RC.1</version>
|
| 36 | </dependency>
|
| 37 | ```
|
| 38 |
|
| 39 | Current production release:
|
| Nicholas Smith | d7c5113 | 2015-09-02 13:14:42 +0100 | [diff] [blame] | 40 |
|
| Nicholas Smith | 15a23ae | 2015-01-14 10:27:51 +0000 | [diff] [blame] | 41 | ```xml
|
| Federico Tomassetti | cf8d7b1 | 2014-07-30 19:00:26 +0100 | [diff] [blame] | 42 | <dependency>
|
| Nicholas Smith | 26c753d | 2015-01-14 10:02:55 +0000 | [diff] [blame] | 43 | <groupId>com.github.javaparser</groupId>
|
| 44 | <artifactId>javaparser-core</artifactId>
|
| Danny van Bruggen | 72b09da | 2016-07-21 11:09:59 +0200 | [diff] [blame] | 45 | <version>2.5.1</version>
|
| Federico Tomassetti | cf8d7b1 | 2014-07-30 19:00:26 +0100 | [diff] [blame] | 46 | </dependency>
|
| Federico Tomassetti | 2051f04 | 2014-07-30 19:01:19 +0100 | [diff] [blame] | 47 | ```
|
| Federico Tomassetti | cf8d7b1 | 2014-07-30 19:00:26 +0100 | [diff] [blame] | 48 |
|
| Nicholas Smith | cd1296d | 2015-01-20 14:22:40 +0000 | [diff] [blame] | 49 | ## How To Compile Sources
|
| Nicholas Smith | 15a23ae | 2015-01-14 10:27:51 +0000 | [diff] [blame] | 50 |
|
| Nicholas Smith | cd1296d | 2015-01-20 14:22:40 +0000 | [diff] [blame] | 51 | If you have checkout the project from GitHub you can build the project with maven using:
|
| Federico Tomassetti | cf8d7b1 | 2014-07-30 19:00:26 +0100 | [diff] [blame] | 52 |
|
| Federico Tomassetti | 2051f04 | 2014-07-30 19:01:19 +0100 | [diff] [blame] | 53 | ```
|
| Federico Tomassetti | cf8d7b1 | 2014-07-30 19:00:26 +0100 | [diff] [blame] | 54 | mvn clean install
|
| Federico Tomassetti | 2051f04 | 2014-07-30 19:01:19 +0100 | [diff] [blame] | 55 | ```
|
| Federico Tomassetti | cf8d7b1 | 2014-07-30 19:00:26 +0100 | [diff] [blame] | 56 |
|
| Danny van Bruggen | 1188750 | 2016-12-05 19:27:34 +0100 | [diff] [blame^] | 57 | 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] | 58 |
|
| 59 | ```
|
| 60 | mvn javacc:javacc
|
| 61 | ```
|
| 62 |
|
| 63 | ## Manual
|
| 64 |
|
| 65 | Examples of how to use the library can be found on the [Manual](https://github.com/javaparser/javaparser/wiki/Manual) page of the wiki
|
| 66 |
|
| Nicholas Smith | 26c753d | 2015-01-14 10:02:55 +0000 | [diff] [blame] | 67 | ## Troubleshooting
|
| 68 |
|
| Danny van Bruggen | 1188750 | 2016-12-05 19:27:34 +0100 | [diff] [blame^] | 69 | First try the [wiki](https://github.com/javaparser/javaparser/wiki).
|
| Nicholas Smith | 26c753d | 2015-01-14 10:02:55 +0000 | [diff] [blame] | 70 |
|
| Danny van Bruggen | 1188750 | 2016-12-05 19:27:34 +0100 | [diff] [blame^] | 71 | Didn't find an answer? Try [searching for existing issues](https://github.com/javaparser/javaparser/issues?utf8=%E2%9C%93&q=is%3Aissue%20)
|
| 72 |
|
| 73 | 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] | 74 |
|
| 75 | ## Javadoc
|
| 76 |
|
| Nicholas Smith | c86a9ff | 2015-08-12 13:20:26 +0100 | [diff] [blame] | 77 | 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] | 78 |
|
| 79 | ## History
|
| 80 |
|
| Didier Villevalois | d5e8843 | 2015-03-16 14:23:45 +0100 | [diff] [blame] | 81 | 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] | 82 |
|
| Didier Villevalois | d5e8843 | 2015-03-16 14:23:45 +0100 | [diff] [blame] | 83 | The project now supports parsing Java 1.8 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] | 84 |
|
| Federico Tomassetti | 43e1e41 | 2015-08-06 17:31:26 +0200 | [diff] [blame] | 85 | ## Related projects
|
| 86 |
|
| Federico Tomassetti | 212fd3f | 2016-10-20 21:41:35 +0200 | [diff] [blame] | 87 | [JavaSymbolSolver](https://github.com/javaparser/javasymbolsolver) is a project from the same committers working on JavaParser.
|
| 88 | You can use it to calculate the type of JavaParser expressions and connecting references with their declarations.
|
| 89 |
|
| Federico Tomassetti | 43e1e41 | 2015-08-06 17:31:26 +0200 | [diff] [blame] | 90 | From JavaParser other projects have been derived:
|
| 91 |
|
| 92 | * [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] | 93 | * [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] | 94 |
|
| 95 | ## Credits
|
| 96 |
|
| 97 | This project has been maintained thanks to the joint efforts of many contributors: we are extremely grateful to all of them.
|
| 98 |
|
| 99 | 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.
|
| 100 |
|
| Didier Villevalois | d5e8843 | 2015-03-16 14:23:45 +0100 | [diff] [blame] | 101 | ## License
|
| Nicholas Smith | 26c753d | 2015-01-14 10:02:55 +0000 | [diff] [blame] | 102 |
|
| Federico Tomassetti | 2c7ba12 | 2015-08-12 08:06:33 +0200 | [diff] [blame] | 103 | 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] | 104 |
|
| 105 | For details about the LGPL License please refer to [LICENSE.LGPL](ttps://github.com/javaparser/javaparser/blob/master/LICENSE.LGPL).
|
| 106 |
|
| 107 | For details about the Apache License please refer to [LICENSE.APACHE](ttps://github.com/javaparser/javaparser/blob/master/LICENSE.APACHE).
|