blob: ecb15056f9e5a4659b88c8ddad048c543cd7bf39 [file] [log] [blame]
import org.apache.xalan.transformer.TransformerImpl;
import org.apache.xalan.trace.TraceManager;
import org.apache.xalan.trace.PrintTraceListener;
public class Trace
{
public static void main (String[] args)
throws java.io.IOException,
org.apache.trax.TransformException, org.apache.trax.ProcessorException,
java.util.TooManyListenersException,
org.xml.sax.SAXException
{
// Set up a PrintTraceListener object to print to a file.
java.io.FileWriter fw = new java.io.FileWriter("events.log");
java.io.PrintWriter pw = new java.io.PrintWriter(fw, true);
PrintTraceListener ptl = new PrintTraceListener(pw);
// Print information as each node is 'executed' in the stylesheet.
ptl.m_traceElements = true;
// Print information after each result-tree generation event.
ptl.m_traceGeneration = true;
// Print information after each selection event.
ptl.m_traceSelection = true;
// Print information whenever a template is invoked.
ptl.m_traceTemplates = true;
// Set up the transformation
org.apache.trax.Processor processor = org.apache.trax.Processor.newInstance("xslt");
org.apache.trax.Templates templates = processor.process
(new org.xml.sax.InputSource("foo.xsl"));
org.apache.trax.Transformer transformer = templates.newTransformer();
// Cast the Transformer object as TransformerImpl.
if (transformer instanceof TransformerImpl)
{
TransformerImpl transformerImpl = (TransformerImpl)transformer;
// Register the TraceListener with a TraceManager associated
// with the TransformerImpl.
TraceManager trMgr = transformerImpl.getTraceManager();
trMgr.addTraceListener(ptl);
// Perform the transformation --printing information to
// the events log during the process.
transformer.transform
( new org.xml.sax.InputSource("foo.xml"),
new org.apache.trax.Result(new java.io.FileWriter("foo.out")) );
}
// Close the PrintWriter and FileWriter.
pw.close();
fw.close();
}
}