I am writing a Maven plugin (Mojo) that imports a Jar library used by other projects. At least one of the classes in that library use Apache Log4j for logging, but Log4j is not going to be properly configured by the logger that Maven provides to the Mojo.
Is there any simple way to bridge between these? Unfortunately, org.apache.log4j.Logger
and org.apache.maven.logging.Log
do not share a common superinterface or superclass, so I can't simply have a setLog()
type function. Any suggestions would be welcome; currently I am planning to either just ignore it, or write a bridge class that can use either.
If you want to write a bridge class, look at SLF4J sources: http://www.slf4j.org/legacy.html#log4j-over-slf4j They are doing something quite similar in their log4j bridge.
I had the same problem and solved writing a simple bridge across Maven Logger and Log4j:
And in my Mojo, I used the BasicConfigurator class of Log4j API, with an instance of this bridge:
I don't know if Maven infrastructure already have this bridge, I haven't tried to search something more "maven-like", but this solution worked fine.