External (Java) annotations. #8900
Open
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This is something I am experimenting for a very long time (the first commit in the old/original personal Mercurial repository holding this experiment is from May 2013).
This proposal is to add a way to (sort-of) add annotations to Java elements that don't appear in the source.
This is useful when the source code cannot be reasonably modified adding the annotations, various editor features may still rely on the annotations.
Note the editor features that want to use this feature need to do so explicitly, as the external annotations are not fully-featured.
The new API is fairly minimal:
ElementUtilities.getAugmentedAnnotationMirrors
to read the annotations, andSourceUtils.attachAnnotation
to add the annotations (augment an element with an annotation). (SourceUtils
being the utils class for things that don't naturally fit anywhere, but are important nonetheless.)This PR also downloads the annotation files for JDK classes from, well, community edition of Idea. So this is not only an "infrastructure building" PR.
The NPECheck hint is tweaked to use the external annotations.
A new
MagicConstantHint
hint is added to more showcase the external annotations.To see a demo of the annotations, this sample can be used:
There should be two new warnings for this file - the
(null)
should get a warning as theor
method does not acceptnull
, andisSet(Modifier.Final)
should get a warning, asModifier.FINAL
is not an expected constant forCalendar.isSet
.There are more usecases for the external annotations, of course.
I am not marking this as a draft, although I expect some cleanup/improvements will still be needed.
What do you think?
Thanks!
^Add meaningful description above
Click to collapse/expand PR instructions
By opening a pull request you confirm that, unless explicitly stated otherwise, the changes -
Please make sure (eg.
git log
) that all commits have a valid name and email address for you in the Author field.If you're a first time contributor, see the Contributing guidelines for more information.
If you're a committer, please label the PR before pressing "Create pull request" so that the right test jobs can run.
PR approval and merge checklist:
If this PR targets the delivery branch: don't merge. (full wiki article)