[jdk8u-dev] RFR: 8151255: javac with a annotation processor returns incorrect error code

Joe Darcy darcy at openjdk.org
Sat Jan 27 17:57:33 UTC 2024


On Fri, 26 Jan 2024 03:53:10 GMT, yangsummer <duke at openjdk.org> wrote:

> Hi,
> 
> When I was building my application using Maven 3.6.3, I had two applications A and B that had a dependency relationship. B relied on A's jar. When I built both A and B simultaneously, A built successfully. Although B threw an exception, Javac believed that B had built successfully. I unpacked B's  jar package and found that there was no class file inside. So I searched for the reason based on the exception information, and found that Javac was divided into multiple rounds when processing annotations. If an abort occurred in a certain round, Javac would not be able to find the delegate compiler. If Javac's own errors were 0 at this time, it would consider compilation successful, but te specific error information was reported to the global diagnosticCollector by the delegate compiler, So even though Maven printed an error, it didn't stop working due to the error, but instead continued to package and ultimately printed an incorrect package.

@liliBestCoder , per general OpenJDK development procedures, a fix like this should first be considered against the mainline release, currently JDK 23, and then if it is fixed in mainline, subsequently possibly backported to earlier release trains. You could also inquire to get feedback on a fix for a bug to the appropriate mailing list before sending the PR, compiler-dev in this case. HTH

-------------

PR Comment: https://git.openjdk.org/jdk8u-dev/pull/432#issuecomment-1913275576


More information about the jdk8u-dev mailing list