-
Notifications
You must be signed in to change notification settings - Fork 5.8k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
8314213: DocLint should warn about unknown standard tags #15314
Conversation
👋 Welcome back prappo! A progress list of the required criteria for merging this PR into |
@pavelrappo The following label will be automatically applied to this pull request:
When this pull request is ready to be reviewed, an "RFR" email will be sent to the corresponding mailing list. If you would like to change these labels, use the /label pull request command. |
I forgot to add one important point. tier1 now also does |
Filed a follow-up bug: https://bugs.openjdk.org/browse/JDK-8314448 |
@pavelrappo This change now passes all automated pre-integration checks. ℹ️ This project also has non-automated pre-integration requirements. Please see the file CONTRIBUTING.md for details. After integration, the commit message for the final commit will be:
You can use pull request commands such as /summary, /contributor and /issue to adjust it as needed. At the time when this comment was updated there had been 5 new commits pushed to the
Please see this link for an up-to-date comparison between the source branch of this pull request and the ➡️ To integrate this PR with the above commit message to the |
we could/should have more tests for some of these situations |
/integrate |
Going to push as commit 6f1071f.
Your commit was automatically rebased without conflicts. |
@pavelrappo Pushed as commit 6f1071f. 💡 You may see a message that your pull request was closed with unmerged commits. This can be safely ignored. |
This PR is primarily informational: aside from adding a few code comments and
assert
statements, it acts as a place to record observations on unknown JavaDoc tag reporting mechanics. Because it's a PR, this text will be automatically sent to the javadoc-dev mailing list and archived for future reference.DocLint can be run in three modes:
javac -Xdoclint
)javadoc -Xdoclint
)test/langtools/tools/doclint/DocLintTester.java
)While the core of all these modes is the same,
jdk.javadoc.internal.doclint.DocLint
, and is capable of reporting on unknown tags, whether an unknown tag will be reported, depends on the core configuration, which differs significantly among these modes.The latter mode is for testing only and can be configured flexibly, but it's of little interest to us. The former two modes are important as they face end user, but are limited in their configuration and, additionally, each has own peculiarities.
In javac mode, DocLint cannot be passed with a list of custom tags: the required wiring is missing. So, when a potentially unknown tag is detected, the error is not raised because
env.customTags == null
:This is why we don't see errors for JDK-specific tags (e.g.
@implSpec
,@implNote
,@apiNote
,@jls
) whenmake images
, during which DocLint is run from javac.In javadoc mode DocLint is passed with a list of custom tags, containing tags captured from
-tag
and-taglet
options. Becausemake docs
runs javadoc with such options for each of the JDK-specific tags, all tags are known, and no errors are reported.Here's a twist though: javadoc has its own machinery for reporting unknown tags. So why don't we see doubling of diagnostics? There should be an error from DocLint and a warning [sic!] from javadoc, but there's only an error. Here's why:
Unknown tags are modelled by two
DocTree
subinterfaces,UnknownInlineTagTree
andUnknownBlockTagTree
, each of which return the name of the captured tag fromgetTagName()
, not fromgetKind().tagName
, which (unsurprisingly) returns null for those two kinds. That means that the body of thisif
block is dead code (i.e. DocLint or not, it's never reached for an unknown tag):Here's another twist: DocLint can be disabled for a javadoc run:
-Xdoclint:none
. When coupled with defunct javadoc reporting, disabled DocLint means that no unknown tags are reported.I don't know which of the above is by mistake and which by design, but it's how it works today. We could address (some of) that in a later PR. Personally, I wouldn't provide missing wiring in javac, given that javac mode has been recently somewhat de-emphasized. That said, I think we should repair javadoc reporting and make sure that either DocLint or javadoc, but not both, report on unknown tags at all times (i.e. whatever the javadoc configuration might be).
Progress
Issue
Reviewers
Reviewing
Using
git
Checkout this PR locally:
$ git fetch https://git.openjdk.org/jdk.git pull/15314/head:pull/15314
$ git checkout pull/15314
Update a local copy of the PR:
$ git checkout pull/15314
$ git pull https://git.openjdk.org/jdk.git pull/15314/head
Using Skara CLI tools
Checkout this PR locally:
$ git pr checkout 15314
View PR using the GUI difftool:
$ git pr show -t 15314
Using diff file
Download this PR as a diff file:
https://git.openjdk.org/jdk/pull/15314.diff
Webrev
Link to Webrev Comment