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="mailto:russgold@acm.org">Russell Gold</a> | ||||
* @author <a href="stefan.bodewig@epost.de">Stefan Bodewig</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; | private File destDir = null; | ||||
@@ -143,6 +144,12 @@ public class XSLTProcess extends MatchingTask { | |||||
} | } | ||||
liaison = getLiaison(); | 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); | log("Using "+liaison.getClass().toString(), Project.MSG_VERBOSE); | ||||
File stylesheet = project.resolveFile(xslFile); | File stylesheet = project.resolveFile(xslFile); | ||||
@@ -60,11 +60,15 @@ import java.io.FileOutputStream; | |||||
import java.io.IOException; | import java.io.IOException; | ||||
import org.apache.tools.ant.taskdefs.XSLTLiaison; | 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.TransformerFactory; | ||||
import javax.xml.transform.Transformer; | import javax.xml.transform.Transformer; | ||||
import javax.xml.transform.TransformerException; | |||||
import javax.xml.transform.Templates; | 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.StreamResult; | ||||
import javax.xml.transform.stream.StreamSource; | import javax.xml.transform.stream.StreamSource; | ||||
import javax.xml.transform.OutputKeys; | 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:dims@yahoo.com">Davanum Srinivas</a> | ||||
* @author <a href="mailto:sbailliez@apache.org">Stephane Bailliez</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 */ | /** The trax TransformerFactory */ | ||||
private TransformerFactory tfactory = null; | private TransformerFactory tfactory = null; | ||||
@@ -90,9 +94,13 @@ public class TraXLiaison implements XSLTLiaison { | |||||
/** transformer */ | /** transformer */ | ||||
private Transformer transformer = null; | private Transformer transformer = null; | ||||
private XSLTLogger logger; | |||||
public TraXLiaison() throws Exception { | public TraXLiaison() throws Exception { | ||||
tfactory = TransformerFactory.newInstance(); | tfactory = TransformerFactory.newInstance(); | ||||
tfactory.setErrorListener(this); | |||||
} | } | ||||
//------------------- IMPORTANT | //------------------- IMPORTANT | ||||
// 1) Don't use the StreamSource(File) ctor. It won't work with | // 1) Don't use the StreamSource(File) ctor. It won't work with | ||||
// xalan prior to 2.2 because of systemid bugs. | // xalan prior to 2.2 because of systemid bugs. | ||||
@@ -111,6 +119,7 @@ public class TraXLiaison implements XSLTLiaison { | |||||
src.setSystemId(getSystemId(stylesheet)); | src.setSystemId(getSystemId(stylesheet)); | ||||
templates = tfactory.newTemplates(src); | templates = tfactory.newTemplates(src); | ||||
transformer = templates.newTransformer(); | transformer = templates.newTransformer(); | ||||
transformer.setErrorListener(this); | |||||
} | } | ||||
public void transform(File infile, File outfile) throws Exception { | 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 { | public void setOutputtype(String type) throws Exception { | ||||
transformer.setOutputProperty(OutputKeys.METHOD, type); | 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 | } //-- TraXLiaison |