Marc Guillemot created MNG-8598: ----------------------------------- Summary: Support for evaluated jvm.config files to improve lombok+ecj support Key: MNG-8598 URL: https://issues.apache.org/jira/browse/MNG-8598 Project: Maven Issue Type: Improvement Components: Command Line Affects Versions: 3.9.6 Reporter: Marc Guillemot
We use lombok together with the ecj compiler in a large project. For that, we use {{lombok.jar}} as java agent for maven (corresponds to the official lombok documentation: [https://projectlombok.org/setup/ecj)|https://projectlombok.org/setup/ecj),]. At the root level of the project, this is quite easy {{.mvn/jvm.config:}} {code:java} -javaagent:lombok.jar=ECJ {code} We want to be able to call mvn in any module of the project, which means that each submodule needs to have its own {{.mvn/jvm.config}} with the relative path to the {{lombok.jar}} file, otherwise maven can't start because the agent is not found: - at depth 1: {{-javaagent:../lombok.jar=ECJ}} - at depth 2: {{-javaagent:../../lombok.jar=ECJ}} - at depth 3: {{-javaagent:../../../lombok.jar=ECJ}} - ... This is naturally very annoying and error prone (new modules need to have their {{.mvn/jvm.config}} and relative paths have to be adapted when moving modules). It seems to me that maven doesn't provide currently any better way to achieve that (I hope, I'm wrong) but that this could be achieved improving the {{{}mvn.bat{}}}/{{{}mvn{}}} scripts with: * interpolation of contained variables ({{{}MAVEN_PROJECTBASEDIR{}}} would be the interesting one) * support for two different {{jvm.config}} files allowing bat/sh specific references for variables. In our case it would be a "sh.jvm.config" with {{-javaagent:$MAVEN_PROJECTBASEDIR/lombok.jar=ECJ}} and a "bat.jvm.config" with {{{}-javaagent:%MAVEN_PROJECTBASEDIR%\lombok.jar=ECJ{}}}. -- This message was sent by Atlassian Jira (v8.20.10#820010)