|Travis Burtrum de38f7add0 Add .travis.yml||4 months ago|
|apt-mirror-api||4 years ago|
|apt-processor||4 years ago|
|core||4 months ago|
|extra||6 years ago|
|netui-compiler||4 years ago|
|netui-compiler-test||5 years ago|
|.gitignore||5 years ago|
|.travis-settings.xml||4 months ago|
|.travis.yml||4 months ago|
|license.txt||6 years ago|
|pom.xml||4 years ago|
|readme.md||6 years ago|
aptIn16 is an implementation of the Annotation Processing Tool (apt) com.sun.mirror.* classes allowing classes implementing them to run as Java 1.6 annotation processors inside of javac (JSR 269). This is orders of magnitude faster than apt. It can be used by anyone who currently relies on apt but would like to switch to the newer/faster javac.
On my companies rather large project using apache beehive annotation processors, compilation of a single module (currently almost 800 .java files, only 300 or so using annotations) using apt took 13 minutes, that same module, using the same beehive processing code, running inside of aptIn16 takes about 45 seconds to compile now, and the output is identical.
Not every method in com.sun.mirror.* has been implemented, basically just the bare minimum to get apache beehive to work, so if you use something different, you may need to implement another method or two. All the non-implemented methods are marked with 'todos' and, if you turn on certain static final booleans in Debug, will print out the method name when called and the class calling it. This is very useful for debugging as I haven't found a good way of debugging processors running inside of javac. If you do implement other methods, or make improvements, please send the code my way so everyone can benefit.
This currently only works with a sun/oracle compiler, this is because Java 6 annotation processors don't have a concept of SourcePosition, which is needed by apt, so I have to use the com.sun.source.tree to get this info. All of the sun-specific code is in com.moparisthebest.mirror.util.ConvertSourcePosition, so if you know how to implement this for eclipse or another compiler, please let me know or do so and send me patches.
The onlyvery hacky part of this is that apt gave the entire command line sent to javac as options to the processor, where as Java 6 style annotation processors only get the options specifically meant for annotation processors, and processors like apache beehive rely on some of these options, the hardest to get of which is -sourcepath, which I can get decently on Java 6, but have to really hack it to get in Java 7. Sun compilers put the arguments in an System property, but there are no delimiters that tells you where one argument begins or ends, so that's a complete hack to try to parse it as well. Basically I try to do my best and not halt program execution if something goes wrong. Please tell me a better way to handle this.
Currently, to use this with your own processors, look at the very simple netui-compiler for examples. apt-processor is a project that should auto-discover and run all apt-style processors automatically, but it isn't quite finished and doesn't currently work with beehive.
Yes, the project is licensed under the GNU/GPLv3, but that shouldn't affect anyone, even those writing propietary code, as your classes don't link to any of this code. It's simply another tool you run over your code to process it. It would be similar to gcc, just because you use it to compile your programs, doesn't mean your programs must now be under the GNU/GPL. If you think you have an issue with this, let me know and I'm sure we can work it out.
git checkout -b my_aptIn16)
git commit -am "Implemented method X")
git push origin my_aptIn16)