Not sure if this is the best way to do this, but I wrap antbuilder in my own class so that I can get ant event messages to my logger
package script.ant import groovy.ant.AntBuilder as AB import org.apache.tools.ant.BuildEvent import org.apache.tools.ant.BuildLogger @groovy.util.logging.Slf4j class AntBuilder { static AB newInstance () { AB ab = new AB() ab.project.buildListeners.each { ab.project.removeBuildListener(it) } ab.antProject.addBuildListener(new BuildLogger() { @Override public void buildStarted (BuildEvent event) { } @Override public void buildFinished (BuildEvent event) { } @Override public void targetStarted (BuildEvent event) { } @Override public void targetFinished (BuildEvent event) { } @Override public void taskStarted (BuildEvent event) { } @Override public void taskFinished (BuildEvent event) { } @Override public void messageLogged (BuildEvent event) { if (event?.task) log.info("[{}] {}", event.task.taskName, event.message) } @Override public void setMessageOutputLevel (int level) { } @Override public void setOutputPrintStream (PrintStream output) { } @Override public void setEmacsMode (boolean emacsMode) { } @Override public void setErrorPrintStream (PrintStream err) { } }) ab } } From: Paul King <pa...@asert.com.au> Date: Tuesday, April 2, 2024 at 5:37 AM To: users@groovy.apache.org <users@groovy.apache.org> Subject: [EXT] Re: making the most of Groovy in Action 2nd edition Hi Dimitar, From Groovy 4, Groovy's "module" jars are fully-compliant with the JPMS rule disallowing split packages. The Groovy 3 and 4 release notes have more details. But basically, for the example you are showing, AntBuilder is now in the groovy.ant package, so if you add the appropriate import, you'll be good to go. AntBuilder was in the groovy.util package in earlier Groovy versions, and so didn't need the import. Mind you, there will likely be numerous places where such changes are needed. We haven't produced an updated version of those examples for Groovy 4. Cheers, Paul. On Tue, Apr 2, 2024 at 8:01 PM Dimitar Vassilev <dimitar.vassi...@gmail.com> wrote: > > Hi all, > > After a bit of extensive bashing, I found some time to re-read Groovy in > Action 2nd edition. > I've downloaded the source code from the publisher also and am wondering how > to make the most from the book provided I run Groovy 4.0.20/Mac 12.7.4 > Running groovysh from the console is fine, but it doesn't always print the > examples > going into the groovy book source > GroovyInAction % groovy alltests.groovy > org.codehaus.groovy.control.MultipleCompilationErrorsException: startup > failed: > /Users/xxxx/GroovyInAction/alltests.groovy: 2: unable to resolve class > AntBuilder > @ line 2, column 15. > def ant = new AntBuilder() > ^ > > 1 error > Thanks!