factory so messages will get back to Ant's logging system. Submitted by: David Leuschner <leuschner-list@gmx.net> git-svn-id: https://svn.apache.org/repos/asf/ant/core/trunk@270089 13f79535-47bb-0310-9956-ffa450edef68master
@@ -0,0 +1,62 @@ | |||
/* | |||
* The Apache Software License, Version 1.1 | |||
* | |||
* Copyright (c) 2001 The Apache Software Foundation. All rights | |||
* reserved. | |||
* | |||
* Redistribution and use in source and binary forms, with or without | |||
* modification, are permitted provided that the following conditions | |||
* are met: | |||
* | |||
* 1. Redistributions of source code must retain the above copyright | |||
* notice, this list of conditions and the following disclaimer. | |||
* | |||
* 2. Redistributions in binary form must reproduce the above copyright | |||
* notice, this list of conditions and the following disclaimer in | |||
* the documentation and/or other materials provided with the | |||
* distribution. | |||
* | |||
* 3. The end-user documentation included with the redistribution, if | |||
* any, must include the following acknowlegement: | |||
* "This product includes software developed by the | |||
* Apache Software Foundation (http://www.apache.org/)." | |||
* Alternately, this acknowlegement may appear in the software itself, | |||
* if and wherever such third-party acknowlegements normally appear. | |||
* | |||
* 4. The names "The Jakarta Project", "Ant", and "Apache Software | |||
* Foundation" must not be used to endorse or promote products derived | |||
* from this software without prior written permission. For written | |||
* permission, please contact apache@apache.org. | |||
* | |||
* 5. Products derived from this software may not be called "Apache" | |||
* nor may "Apache" appear in their names without prior written | |||
* permission of the Apache Group. | |||
* | |||
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED | |||
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES | |||
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | |||
* DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR | |||
* ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | |||
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | |||
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF | |||
* USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | |||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | |||
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT | |||
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF | |||
* SUCH DAMAGE. | |||
* ==================================================================== | |||
* | |||
* This software consists of voluntary contributions made by many | |||
* individuals on behalf of the Apache Software Foundation. For more | |||
* information on the Apache Software Foundation, please see | |||
* <http://www.apache.org/>. | |||
*/ | |||
package org.apache.tools.ant.taskdefs; | |||
public interface XSLTLogger { | |||
/** | |||
* Log a message. | |||
*/ | |||
void log(String msg); | |||
} |
@@ -0,0 +1,59 @@ | |||
/* | |||
* The Apache Software License, Version 1.1 | |||
* | |||
* Copyright (c) 2001 The Apache Software Foundation. All rights | |||
* reserved. | |||
* | |||
* Redistribution and use in source and binary forms, with or without | |||
* modification, are permitted provided that the following conditions | |||
* are met: | |||
* | |||
* 1. Redistributions of source code must retain the above copyright | |||
* notice, this list of conditions and the following disclaimer. | |||
* | |||
* 2. Redistributions in binary form must reproduce the above copyright | |||
* notice, this list of conditions and the following disclaimer in | |||
* the documentation and/or other materials provided with the | |||
* distribution. | |||
* | |||
* 3. The end-user documentation included with the redistribution, if | |||
* any, must include the following acknowlegement: | |||
* "This product includes software developed by the | |||
* Apache Software Foundation (http://www.apache.org/)." | |||
* Alternately, this acknowlegement may appear in the software itself, | |||
* if and wherever such third-party acknowlegements normally appear. | |||
* | |||
* 4. The names "The Jakarta Project", "Ant", and "Apache Software | |||
* Foundation" must not be used to endorse or promote products derived | |||
* from this software without prior written permission. For written | |||
* permission, please contact apache@apache.org. | |||
* | |||
* 5. Products derived from this software may not be called "Apache" | |||
* nor may "Apache" appear in their names without prior written | |||
* permission of the Apache Group. | |||
* | |||
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED | |||
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES | |||
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | |||
* DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR | |||
* ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | |||
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | |||
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF | |||
* USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | |||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | |||
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT | |||
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF | |||
* SUCH DAMAGE. | |||
* ==================================================================== | |||
* | |||
* This software consists of voluntary contributions made by many | |||
* individuals on behalf of the Apache Software Foundation. For more | |||
* information on the Apache Software Foundation, please see | |||
* <http://www.apache.org/>. | |||
*/ | |||
package org.apache.tools.ant.taskdefs; | |||
public interface XSLTLoggerAware { | |||
void setLogger(XSLTLogger l); | |||
} |
@@ -92,7 +92,8 @@ import org.apache.tools.ant.util.FileUtils; | |||
* @author <a href="mailto:russgold@acm.org">Russell Gold</a> | |||
* @author <a href="stefan.bodewig@epost.de">Stefan Bodewig</a> | |||
*/ | |||
public class XSLTProcess extends MatchingTask { | |||
public class XSLTProcess extends MatchingTask implements XSLTLogger { | |||
private File destDir = null; | |||
@@ -143,6 +144,12 @@ public class XSLTProcess extends MatchingTask { | |||
} | |||
liaison = getLiaison(); | |||
// check if liaison wants to log errors using us as logger | |||
if(liaison instanceof XSLTLoggerAware) { | |||
((XSLTLoggerAware)liaison).setLogger(this); | |||
} | |||
log("Using "+liaison.getClass().toString(), Project.MSG_VERBOSE); | |||
File stylesheet = project.resolveFile(xslFile); | |||
@@ -60,11 +60,15 @@ import java.io.FileOutputStream; | |||
import java.io.IOException; | |||
import org.apache.tools.ant.taskdefs.XSLTLiaison; | |||
import org.apache.tools.ant.taskdefs.XSLTLoggerAware; | |||
import org.apache.tools.ant.taskdefs.XSLTLogger; | |||
import javax.xml.transform.TransformerFactory; | |||
import javax.xml.transform.Transformer; | |||
import javax.xml.transform.TransformerException; | |||
import javax.xml.transform.Templates; | |||
import javax.xml.transform.Source; | |||
import javax.xml.transform.ErrorListener; | |||
import javax.xml.transform.stream.StreamResult; | |||
import javax.xml.transform.stream.StreamSource; | |||
import javax.xml.transform.OutputKeys; | |||
@@ -76,7 +80,7 @@ import javax.xml.transform.OutputKeys; | |||
* @author <a href="mailto:dims@yahoo.com">Davanum Srinivas</a> | |||
* @author <a href="mailto:sbailliez@apache.org">Stephane Bailliez</a> | |||
*/ | |||
public class TraXLiaison implements XSLTLiaison { | |||
public class TraXLiaison implements XSLTLiaison, ErrorListener, XSLTLoggerAware { | |||
/** The trax TransformerFactory */ | |||
private TransformerFactory tfactory = null; | |||
@@ -90,9 +94,13 @@ public class TraXLiaison implements XSLTLiaison { | |||
/** transformer */ | |||
private Transformer transformer = null; | |||
private XSLTLogger logger; | |||
public TraXLiaison() throws Exception { | |||
tfactory = TransformerFactory.newInstance(); | |||
tfactory.setErrorListener(this); | |||
} | |||
//------------------- IMPORTANT | |||
// 1) Don't use the StreamSource(File) ctor. It won't work with | |||
// xalan prior to 2.2 because of systemid bugs. | |||
@@ -111,6 +119,7 @@ public class TraXLiaison implements XSLTLiaison { | |||
src.setSystemId(getSystemId(stylesheet)); | |||
templates = tfactory.newTemplates(src); | |||
transformer = templates.newTransformer(); | |||
transformer.setErrorListener(this); | |||
} | |||
public void transform(File infile, File outfile) throws Exception { | |||
@@ -165,4 +174,47 @@ public class TraXLiaison implements XSLTLiaison { | |||
public void setOutputtype(String type) throws Exception { | |||
transformer.setOutputProperty(OutputKeys.METHOD, type); | |||
} | |||
public void setLogger(XSLTLogger l) { | |||
logger = l; | |||
} | |||
public void error(TransformerException e) { | |||
logError(e, "Error"); | |||
} | |||
public void fatalError(TransformerException e) { | |||
logError(e, "Fatal Error"); | |||
} | |||
public void warning(TransformerException e) { | |||
logError(e, "Warning"); | |||
} | |||
private void logError(TransformerException e, String type) { | |||
StringBuffer msg = new StringBuffer(); | |||
if(e.getLocator() != null) { | |||
if(e.getLocator().getSystemId() != null) { | |||
String url = e.getLocator().getSystemId(); | |||
if(url.startsWith("file:///")) url = url.substring(8); | |||
msg.append(url); | |||
} else { | |||
msg.append("Unknown file"); | |||
} | |||
if(e.getLocator().getLineNumber() != -1) { | |||
msg.append(":"+e.getLocator().getLineNumber()); | |||
if(e.getLocator().getColumnNumber() != -1) { | |||
msg.append(":"+e.getLocator().getColumnNumber()); | |||
} | |||
} | |||
} | |||
msg.append(": "+type+"! "); | |||
msg.append(e.getMessage()); | |||
if(e.getCause() != null) { | |||
msg.append(" Cause: "+e.getCause()); | |||
} | |||
logger.log(msg.toString()); | |||
} | |||
} //-- TraXLiaison |