X-Git-Url: http://git.argeo.org/?a=blobdiff_plain;f=org.argeo.slc.core%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fslc%2Fant%2FAntRegistryUtil.java;fp=org.argeo.slc.core%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fslc%2Fant%2FAntRegistryUtil.java;h=f9928708a23e20086301f8a742e6a384813212d3;hb=07315a82eb7fa5b84db60209dbf03bd94568321c;hp=8bb0ffcb7efc67d1ea27692cd4fd00ec586d3699;hpb=7c4818a7529a7698e850ca40bb3e7d44d1b4d9e3;p=gpl%2Fargeo-slc.git diff --git a/org.argeo.slc.core/src/main/java/org/argeo/slc/ant/AntRegistryUtil.java b/org.argeo.slc.core/src/main/java/org/argeo/slc/ant/AntRegistryUtil.java index 8bb0ffcb7..f9928708a 100644 --- a/org.argeo.slc.core/src/main/java/org/argeo/slc/ant/AntRegistryUtil.java +++ b/org.argeo.slc.core/src/main/java/org/argeo/slc/ant/AntRegistryUtil.java @@ -8,6 +8,7 @@ import java.util.Properties; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; +import org.apache.tools.ant.BuildException; import org.apache.tools.ant.Project; import org.apache.tools.ant.ProjectHelper; @@ -56,7 +57,8 @@ public class AntRegistryUtil { .getReference(SlcProjectHelper.REF_STRUCTURE_REGISTRY); registry.setMode(StructureRegistry.ACTIVE); registry.setActivePaths(activePaths); - p.executeTarget(p.getDefaultTarget()); + + runProject(p, null); return p; } @@ -71,7 +73,8 @@ public class AntRegistryUtil { ProjectHelper helper = new SlcProjectHelper(); p.addReference(ProjectHelper.PROJECTHELPER_REFERENCE, helper); helper.parse(p, antFile); - p.executeTarget(target != null ? target : p.getDefaultTarget()); + + runProject(p, target); return p; } @@ -81,15 +84,20 @@ public class AntRegistryUtil { log.debug("Runs all paths of Ant URL " + url); Project p = new Project(); p.setUserProperty("ant.file", url.toString()); - //p.setBaseDir(url.toString()); + // p.setBaseDir(url.toString()); p.init(); ProjectHelper helper = new SlcProjectHelper(); p.addReference(ProjectHelper.PROJECTHELPER_REFERENCE, helper); helper.parse(p, url); - for(Map.Entry entry : properties.entrySet()){ - p.setUserProperty(entry.getKey().toString(), entry.getValue().toString()); + + if (properties != null) { + for (Map.Entry entry : properties.entrySet()) { + p.setUserProperty(entry.getKey().toString(), entry.getValue() + .toString()); + } } - p.executeTarget(target != null ? target : p.getDefaultTarget()); + + runProject(p, target); return p; } @@ -97,4 +105,16 @@ public class AntRegistryUtil { public static Project runAll(File antFile) { return runAll(antFile, null); } + + protected static void runProject(Project p, String target) { + p.fireBuildStarted(); + Throwable exception = null; + try { + p.executeTarget(target != null ? target : p.getDefaultTarget()); + } catch (Throwable e) { + exception = e; + } finally { + p.fireBuildFinished(exception); + } + } }