Browse Source

Added a TraX liaison for the <style> task. This enables Apache's Xalan2

and Sun's JAXP1.1 implementations to be used.

I don't expect many developers to have multiple XSLT implementations in
their classpath, but if they do, I made the TraX liaison the default
for several reasons:
  1) It is standard
  2) It is the most modern interface
  3) It is designed as an pluggable interface, so in theory (though perhaps
     down the road a bit), it should be the only liaison required.


git-svn-id: https://svn.apache.org/repos/asf/ant/core/trunk@268394 13f79535-47bb-0310-9956-ffa450edef68
master
Sam Ruby 24 years ago
parent
commit
70ea62a03d
2 changed files with 124 additions and 6 deletions
  1. +15
    -6
      src/main/org/apache/tools/ant/taskdefs/XSLTProcess.java
  2. +109
    -0
      src/main/org/apache/tools/ant/taskdefs/optional/TraXLiaison.java

+ 15
- 6
src/main/org/apache/tools/ant/taskdefs/XSLTProcess.java View File

@@ -130,16 +130,20 @@ public class XSLTProcess extends MatchingTask {
scanner = getDirectoryScanner(baseDir);
log("Transforming into "+destDir, Project.MSG_INFO);

// if processor wasn't specified, default it to xslp or xalan,
// depending on which is in the classpath
// if processor wasn't specified, see if TraX is available. If not,
// default it to xslp or xalan, depending on which is in the classpath
if (liaison == null) {
try {
setProcessor("xslp");
setProcessor("trax");
} catch (Throwable e1) {
try {
setProcessor("xalan");
setProcessor("xslp");
} catch (Throwable e2) {
throw new BuildException(e2);
try {
setProcessor("xalan");
} catch (Throwable e3) {
throw new BuildException(e1);
}
}
}
}
@@ -220,8 +224,13 @@ public class XSLTProcess extends MatchingTask {
* Sets the file to use for styling relative to the base directory.
*/
public void setProcessor(String processor) throws Exception {
System.out.println("trying " + processor);

if (processor.equals("xslp")) {
if (processor.equals("trax")) {
final Class clazz =
Class.forName("org.apache.tools.ant.taskdefs.optional.TraXLiaison");
liaison = (XSLTLiaison)clazz.newInstance();
} else if (processor.equals("xslp")) {
final Class clazz =
Class.forName("org.apache.tools.ant.taskdefs.optional.XslpLiaison");
liaison = (XSLTLiaison) clazz.newInstance();


+ 109
- 0
src/main/org/apache/tools/ant/taskdefs/optional/TraXLiaison.java View File

@@ -0,0 +1,109 @@
/*
* The Apache Software License, Version 1.1
*
* Copyright (c) 1999 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.optional;

import java.io.FileOutputStream;

import org.apache.tools.ant.taskdefs.XSLTLiaison;

import javax.xml.transform.TransformerFactory;
import javax.xml.transform.Transformer;
import javax.xml.transform.Templates;
import javax.xml.transform.stream.StreamResult;
import javax.xml.transform.stream.StreamSource;

/**
*
* @author <a href="mailto:rubys@us.ibm.com">Sam Ruby</a>
* @author <a href="mailto:dims@yahoo.com">Davanum Srinivas</a>
* @version $Revision$ $Date$
*/
public class TraXLiaison implements XSLTLiaison {

protected final static String FILEURL = "file:";

/** The trax TransformerFactory */
private TransformerFactory tfactory = null;

/** Stylesheet template */
private Templates templates = null;

/** The trax Transformer itself */
private Transformer transformer;

public TraXLiaison() throws Exception {
tfactory = TransformerFactory.newInstance();
}

public void setStylesheet(String fileName) throws Exception {
templates = tfactory.newTemplates(new StreamSource(normalize(fileName)));
transformer = templates.newTransformer();
};

public void transform(String infile, String outfile) throws Exception {
transformer.transform(new StreamSource(normalize(infile)), new StreamResult(new FileOutputStream(outfile)));
}

protected String normalize(String fileName) {
if(fileName != null && !fileName.startsWith(FILEURL)) {
return FILEURL + fileName;
}
return fileName;
}
public void addParam(String name, String value){
transformer.setParameter(name, value);
}
} //-- TraXLiaison

Loading…
Cancel
Save