You are viewing a plain text version of this content. The canonical link for it is here.
Posted to notifications@logging.apache.org by "Stamatis Zampetakis (Jira)" <ji...@apache.org> on 2022/09/27 12:05:00 UTC

[jira] [Created] (LOG4J2-3609) javac error when PluginProcessor (log4j-core jar) is in the classpath and annotation is not

Stamatis Zampetakis created LOG4J2-3609:
-------------------------------------------

             Summary: javac error when PluginProcessor (log4j-core jar) is in the classpath and annotation is not
                 Key: LOG4J2-3609
                 URL: https://issues.apache.org/jira/browse/LOG4J2-3609
             Project: Log4j 2
          Issue Type: Bug
          Components: Core
    Affects Versions: 2.19.0
         Environment: The problem seems to be reproducible in every JDK. I tested with JDK 8, 11, 19, and 19.
            Reporter: Stamatis Zampetakis


Java compilation (javac) fails to compile a class when the following conditions hold:
* the class transitively depends on an annotation;
* the annotation is not in the classpath;
* the log4j annotation processor (PluginProcessor) is in the classpath.

Assuming that {{MyAnnotation.class}} is not in the classpath the error is the one shown below.

{noformat}
error: cannot access MyAnnotation
  class file for MyAnnotation not found
1 error
{noformat}

I admit that not including the annotation in the classpath could be considered a problem in general but there is no reason why the compilation should fail only when the log4j jar is in the classpath.

It is pretty clear that the problem is related to the annotation processor present in log4j-core jar (PluginProcessor) cause removing the respective entries from the jar allows compilation to complete sucessfully.

From the JDK perspective, it seems that this scenario was considered as a bug and was fixed somewhere in JDK6 allowing compilation to proceed even when annotations are missing from the classpath:
https://bugs.java.com/bugdatabase/view_bug.do?bug_id=6365854

I will upload a minimal scenario with exact steps to reproduce the problem in a few minutes.



--
This message was sent by Atlassian Jira
(v8.20.10#820010)