diff options
Diffstat (limited to 'src/codegen')
-rw-r--r-- | src/codegen/java/org/apache/fop/tools/EventProducerCollector.java | 21 | ||||
-rw-r--r-- | src/codegen/java/org/apache/fop/tools/EventProducerCollectorTask.java | 76 |
2 files changed, 55 insertions, 42 deletions
diff --git a/src/codegen/java/org/apache/fop/tools/EventProducerCollector.java b/src/codegen/java/org/apache/fop/tools/EventProducerCollector.java index 5cefc1d4a..4721f41df 100644 --- a/src/codegen/java/org/apache/fop/tools/EventProducerCollector.java +++ b/src/codegen/java/org/apache/fop/tools/EventProducerCollector.java @@ -21,7 +21,9 @@ package org.apache.fop.tools; import java.io.File; import java.io.IOException; +import java.util.ArrayList; import java.util.Collections; +import java.util.List; import java.util.Map; import org.apache.fop.events.EventProducer; @@ -61,7 +63,7 @@ class EventProducerCollector { } private DocletTagFactory tagFactory; - private EventModel model = new EventModel(); + private List models = new ArrayList(); /** * Creates a new EventProducerCollector. @@ -128,7 +130,9 @@ class EventProducerCollector { EventMethodModel methodMeta = createMethodModel(method); prodMeta.addMethod(methodMeta); } - this.model.addProducer(prodMeta); + EventModel model = new EventModel(); + model.addProducer(prodMeta); + models.add(model); } private EventMethodModel createMethodModel(JavaMethod method) @@ -193,17 +197,8 @@ class EventProducerCollector { * Returns the event model that has been accumulated. * @return the event model. */ - public EventModel getModel() { - return this.model; - } - - /** - * Saves the accumulated event model to an XML file. - * @param modelFile the target model file - * @throws IOException if an I/O error occurs - */ - public void saveModelToXML(File modelFile) throws IOException { - getModel().saveToXML(modelFile); + public List getModels() { + return this.models; } } diff --git a/src/codegen/java/org/apache/fop/tools/EventProducerCollectorTask.java b/src/codegen/java/org/apache/fop/tools/EventProducerCollectorTask.java index b089a361e..a79dfc975 100644 --- a/src/codegen/java/org/apache/fop/tools/EventProducerCollectorTask.java +++ b/src/codegen/java/org/apache/fop/tools/EventProducerCollectorTask.java @@ -47,6 +47,9 @@ import org.apache.tools.ant.Task; import org.apache.tools.ant.types.FileSet; import org.apache.tools.ant.types.selectors.FilenameSelector; +import org.apache.fop.events.model.EventModel; +import org.apache.fop.events.model.EventProducerModel; + /** * Ant task which inspects a file set for Java interfaces which extend the * {@link org.apache.fop.events.EventProducer} interface. For all such interfaces an event model @@ -56,7 +59,7 @@ import org.apache.tools.ant.types.selectors.FilenameSelector; public class EventProducerCollectorTask extends Task { private List filesets = new java.util.ArrayList(); - private File modelFile; + private File destDir; private File translationFile; /** {@inheritDoc} */ @@ -64,19 +67,23 @@ public class EventProducerCollectorTask extends Task { try { EventProducerCollector collector = new EventProducerCollector(); long lastModified = processFileSets(collector); - File parentDir = getModelFile().getParentFile(); - if (!parentDir.exists() && !parentDir.mkdirs()) { - throw new BuildException( - "Could not create target directory for event model file: " + parentDir); - } - if (!getModelFile().exists() || lastModified > getModelFile().lastModified()) { - collector.saveModelToXML(getModelFile()); - log("Event model written to " + getModelFile()); - } - if (getTranslationFile() != null) { - if (!getTranslationFile().exists() - || lastModified > getTranslationFile().lastModified()) { - updateTranslationFile(); + for (Iterator iter = collector.getModels().iterator(); iter.hasNext();) { + EventModel model = (EventModel) iter.next(); + File parentDir = getParentDir(model); + if (!parentDir.exists() && !parentDir.mkdirs()) { + throw new BuildException( + "Could not create target directory for event model file: " + parentDir); + } + File modelFile = new File(parentDir, "event-model.xml"); + if (!modelFile.exists() || lastModified > modelFile.lastModified()) { + model.saveToXML(modelFile); + log("Event model written to " + modelFile); + } + if (getTranslationFile() != null) { + if (!getTranslationFile().exists() + || lastModified > getTranslationFile().lastModified()) { + updateTranslationFile(modelFile); + } } } } catch (ClassNotFoundException e) { @@ -91,18 +98,34 @@ public class EventProducerCollectorTask extends Task { private static final String MODEL2TRANSLATION = "model2translation.xsl"; private static final String MERGETRANSLATION = "merge-translation.xsl"; + private File getParentDir(EventModel model) { + Iterator iter = model.getProducers(); + assert iter.hasNext(); + EventProducerModel producer = (EventProducerModel) iter.next(); + assert !iter.hasNext(); + String interfaceName = producer.getInterfaceName(); + int startLocalName = interfaceName.lastIndexOf("."); + if (startLocalName < 0) { + return destDir; + } else { + String dirname = interfaceName.substring(0, startLocalName); + dirname = dirname.replace('.', File.separatorChar); + return new File(destDir, dirname); + } + } + /** * Updates the translation file with new entries for newly found event producer methods. * @throws IOException if an I/O error occurs */ - protected void updateTranslationFile() throws IOException { + protected void updateTranslationFile(File modelFile) throws IOException { try { boolean resultExists = getTranslationFile().exists(); SAXTransformerFactory tFactory = (SAXTransformerFactory)SAXTransformerFactory.newInstance(); //Generate fresh generated translation file as template - Source src = new StreamSource(getModelFile().toURI().toURL().toExternalForm()); + Source src = new StreamSource(modelFile.toURI().toURL().toExternalForm()); StreamSource xslt1 = new StreamSource( getClass().getResourceAsStream(MODEL2TRANSLATION)); if (xslt1.getInputStream() == null) { @@ -204,19 +227,15 @@ public class EventProducerCollectorTask extends Task { } /** - * Sets the model file to be written. - * @param f the model file + * Sets the destination directory for the event models. + * + * @param destDir the destination directory */ - public void setModelFile(File f) { - this.modelFile = f; - } - - /** - * Returns the model file to be written. - * @return the model file - */ - public File getModelFile() { - return this.modelFile; + public void setDestDir(File destDir) { + if (!destDir.isDirectory()) { + throw new IllegalArgumentException("destDir must be a directory"); + } + this.destDir = destDir; } /** @@ -257,7 +276,6 @@ public class EventProducerCollectorTask extends Task { File targetDir = new File("build/codegen1"); targetDir.mkdirs(); - generator.setModelFile(new File("D:/out.xml")); generator.setTranslationFile(new File("D:/out1.xml")); generator.execute(); } catch (Exception e) { |