blob: 406bf7bfbd3076d8536b5f0d2a4a209930f53856 [file] [log] [blame]
<HTML><HEAD><META CONTENT="text/html; charset=UTF-8" HTTP-EQUIV="Content-Type"/><TITLE>EMMA Coverage Report</TITLE><STYLE TYPE="text/css"> TABLE,TD,TH {border-style:solid; border-color:black;} TD,TH {background:white;margin:0;line-height:100%;padding-left:0.5em;padding-right:0.5em;} TD {border-width:0 1px 0 0;} TH {border-width:1px 1px 1px 0;} TR TD.h {color:red;} TABLE {border-spacing:0; border-collapse:collapse;border-width:0 0 1px 1px;} P,H1,H2,H3,TH {font-family:verdana,arial,sans-serif;font-size:10pt;} TD {font-family:courier,monospace;font-size:10pt;} TABLE.hdft {border-spacing:0;border-collapse:collapse;border-style:none;} TABLE.hdft TH,TABLE.hdft TD {border-style:none;line-height:normal;} TABLE.hdft TH.tl,TABLE.hdft TD.tl {background:#6699CC;color:white;} TABLE.hdft TD.nv {background:#6633DD;color:white;} .nv A:link {color:white;} .nv A:visited {color:white;} .nv A:active {color:yellow;} TABLE.hdft A:link {color:white;} TABLE.hdft A:visited {color:white;} TABLE.hdft A:active {color:yellow;} .in {color:#356085;} TABLE.s TD {padding-left:0.25em;padding-right:0.25em;} TABLE.s TD.l {padding-left:0.25em;padding-right:0.25em;text-align:right;background:#F0F0F0;} TABLE.s TR.z TD {background:#FF9999;} TABLE.s TR.p TD {background:#FFFF88;} TABLE.s TR.c TD {background:#CCFFCC;} A:link {color:#0000EE;text-decoration:none;} A:visited {color:#0000EE;text-decoration:none;} A:hover {color:#0000EE;text-decoration:underline;} TABLE.cn {border-width:0 0 1px 0;} TABLE.s {border-width:1px 0 1px 1px;} TD.h {color:red;border-width:0 1px 0 0;} TD.f {border-width:0 1px 0 1px;} TD.hf {color:red;border-width:0 1px 0 1px;} TH.f {border-width:1px 1px 1px 1px;} TR.cis TD {background:#F0F0F0;} TR.cis TD {border-width:1px 1px 1px 0;} TR.cis TD.h {color:red;border-width:1px 1px 1px 0;} TR.cis TD.f {border-width:1px 1px 1px 1px;} TR.cis TD.hf {color:red;border-width:1px 1px 1px 1px;} TD.b {border-style:none;background:transparent;line-height:50%;} TD.bt {border-width:1px 0 0 0;background:transparent;line-height:50%;} TR.o TD {background:#F0F0F0;}TABLE.it {border-style:none;}TABLE.it TD,TABLE.it TH {border-style:none;}</STYLE></HEAD><BODY><TABLE CLASS="hdft" CELLSPACING="0" WIDTH="100%"><TR><TH CLASS="tl"><A HREF="http://www.eclemma.org/">EMMA</A> Coverage Report (generated Fri Feb 20 18:44:54 GMT 2009)</TH></TR><TR><TD CLASS="nv">[<A HREF="../xslUnitTestCoverage.html">all classes</A>][<A HREF="57.html">org.eclipse.wst.xsl.jaxp.debug.invoker.internal</A>]</TD></TR></TABLE><H2>COVERAGE SUMMARY FOR SOURCE FILE [<SPAN CLASS="in">JAXPSAXProcessorInvoker.java</SPAN>]</H2><TABLE CELLSPACING="0" WIDTH="100%"><TR><TH>name</TH><TH>class, %</TH><TH>method, %</TH><TH>block, %</TH><TH>line, %</TH></TR><TR><TD>JAXPSAXProcessorInvoker.java</TD><TD CLASS="h">0%   (0/2)</TD><TD CLASS="h">0%   (0/13)</TD><TD CLASS="h">0%   (0/364)</TD><TD CLASS="h">0%   (0/78)</TD></TR></TABLE><H3>COVERAGE BREAKDOWN BY CLASS AND METHOD</H3><TABLE CLASS="cn" CELLSPACING="0" WIDTH="100%"><TR><TH CLASS="f">name</TH><TH>class, %</TH><TH>method, %</TH><TH>block, %</TH><TH>line, %</TH></TR><TR><TD CLASS="b"> </TD><TD CLASS="b"> </TD><TD CLASS="b"> </TD><TD CLASS="b"> </TD><TD CLASS="b"> </TD></TR><TR CLASS="cis"><TD CLASS="f">class <A HREF="#0">JAXPSAXProcessorInvoker</A></TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/9)</TD><TD CLASS="h">0%   (0/341)</TD><TD CLASS="h">0%   (0/71)</TD></TR><TR><TD CLASS="f"><A HREF="#0">&lt;static initializer&gt;</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/18)</TD><TD CLASS="h">0%   (0/2)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#2">JAXPSAXProcessorInvoker (): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/7)</TD><TD CLASS="h">0%   (0/3)</TD></TR><TR><TD CLASS="f"><A HREF="#3">addStylesheet (Source, URIResolver, Map, Properties): Transformer</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/145)</TD><TD CLASS="h">0%   (0/31)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#4">addStylesheet (URL, Map, Properties, URIResolver): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/19)</TD><TD CLASS="h">0%   (0/4)</TD></TR><TR><TD CLASS="f"><A HREF="#5">createReader (): XMLReader</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/9)</TD><TD CLASS="h">0%   (0/3)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#6">createTransformerFactory (): TransformerFactory</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/14)</TD><TD CLASS="h">0%   (0/3)</TD></TR><TR><TD CLASS="f"><A HREF="#7">setAttributes (Map): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/44)</TD><TD CLASS="h">0%   (0/8)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#8">transform (InputSource, Result): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/76)</TD><TD CLASS="h">0%   (0/15)</TD></TR><TR><TD CLASS="f"><A HREF="#9">transform (URL, Result): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/9)</TD><TD CLASS="h">0%   (0/2)</TD></TR><TR><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD></TR><TR CLASS="cis"><TD CLASS="f">class <A HREF="#a">JAXPSAXProcessorInvoker$1</A></TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/4)</TD><TD CLASS="h">0%   (0/23)</TD><TD CLASS="h">0%   (0/8)</TD></TR><TR><TD CLASS="f"><A HREF="#a">JAXPSAXProcessorInvoker$1 (JAXPSAXProcessorInvoker): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/6)</TD><TD CLASS="h">0%   (0/2)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#c">error (TransformerException): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/5)</TD><TD CLASS="h">0%   (0/2)</TD></TR><TR><TD CLASS="f"><A HREF="#d">fatalError (TransformerException): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/7)</TD><TD CLASS="h">0%   (0/2)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#e">warning (TransformerException): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/5)</TD><TD CLASS="h">0%   (0/2)</TD></TR></TABLE><P></P><TABLE CLASS="s" CELLSPACING="0" WIDTH="100%"><TR CLASS="z"><TD CLASS="l">1</TD><TD>/*******************************************************************************</TD></TR><TR><TD CLASS="l">2</TD><TD> * Copyright (c) 2007 Chase Technology Ltd - http://www.chasetechnology.co.uk</TD></TR><TR><TD CLASS="l">3</TD><TD> * All rights reserved. This program and the accompanying materials</TD></TR><TR><TD CLASS="l">4</TD><TD> * are made available under the terms of the Eclipse Public License v1.0</TD></TR><TR><TD CLASS="l">5</TD><TD> * which accompanies this distribution, and is available at</TD></TR><TR><TD CLASS="l">6</TD><TD> * http://www.eclipse.org/legal/epl-v10.html</TD></TR><TR><TD CLASS="l">7</TD><TD> *</TD></TR><TR><TD CLASS="l">8</TD><TD> * Contributors:</TD></TR><TR><TD CLASS="l">9</TD><TD> *     Doug Satchwell (Chase Technology Ltd) - initial API and implementation</TD></TR><TR><TD CLASS="l">10</TD><TD> *******************************************************************************/</TD></TR><TR><TD CLASS="l">11</TD><TD>package org.eclipse.wst.xsl.jaxp.debug.invoker.internal;</TD></TR><TR><TD CLASS="l">12</TD><TD> </TD></TR><TR><TD CLASS="l">13</TD><TD>import java.net.URL;</TD></TR><TR><TD CLASS="l">14</TD><TD>import java.util.Collections;</TD></TR><TR><TD CLASS="l">15</TD><TD>import java.util.Iterator;</TD></TR><TR><TD CLASS="l">16</TD><TD>import java.util.Map;</TD></TR><TR><TD CLASS="l">17</TD><TD>import java.util.Properties;</TD></TR><TR><TD CLASS="l">18</TD><TD> </TD></TR><TR><TD CLASS="l">19</TD><TD>import javax.xml.parsers.ParserConfigurationException;</TD></TR><TR><TD CLASS="l">20</TD><TD>import javax.xml.parsers.SAXParserFactory;</TD></TR><TR><TD CLASS="l">21</TD><TD>import javax.xml.transform.ErrorListener;</TD></TR><TR><TD CLASS="l">22</TD><TD>import javax.xml.transform.Result;</TD></TR><TR><TD CLASS="l">23</TD><TD>import javax.xml.transform.Source;</TD></TR><TR><TD CLASS="l">24</TD><TD>import javax.xml.transform.Transformer;</TD></TR><TR><TD CLASS="l">25</TD><TD>import javax.xml.transform.TransformerConfigurationException;</TD></TR><TR><TD CLASS="l">26</TD><TD>import javax.xml.transform.TransformerException;</TD></TR><TR><TD CLASS="l">27</TD><TD>import javax.xml.transform.TransformerFactory;</TD></TR><TR><TD CLASS="l">28</TD><TD>import javax.xml.transform.TransformerFactoryConfigurationError;</TD></TR><TR><TD CLASS="l">29</TD><TD>import javax.xml.transform.URIResolver;</TD></TR><TR><TD CLASS="l">30</TD><TD>import javax.xml.transform.sax.SAXResult;</TD></TR><TR><TD CLASS="l">31</TD><TD>import javax.xml.transform.sax.SAXSource;</TD></TR><TR><TD CLASS="l">32</TD><TD>import javax.xml.transform.sax.SAXTransformerFactory;</TD></TR><TR><TD CLASS="l">33</TD><TD>import javax.xml.transform.sax.TransformerHandler;</TD></TR><TR><TD CLASS="l">34</TD><TD> </TD></TR><TR><TD CLASS="l">35</TD><TD>import org.apache.commons.logging.Log;</TD></TR><TR><TD CLASS="l">36</TD><TD>import org.apache.commons.logging.LogFactory;</TD></TR><TR><TD CLASS="l">37</TD><TD>import org.eclipse.wst.xsl.jaxp.debug.invoker.IProcessorInvoker;</TD></TR><TR><TD CLASS="l">38</TD><TD>import org.eclipse.wst.xsl.jaxp.debug.invoker.TransformationException;</TD></TR><TR><TD CLASS="l">39</TD><TD>import org.xml.sax.InputSource;</TD></TR><TR><TD CLASS="l">40</TD><TD>import org.xml.sax.SAXException;</TD></TR><TR><TD CLASS="l">41</TD><TD>import org.xml.sax.SAXNotRecognizedException;</TD></TR><TR><TD CLASS="l">42</TD><TD>import org.xml.sax.SAXNotSupportedException;</TD></TR><TR><TD CLASS="l">43</TD><TD>import org.xml.sax.XMLReader;</TD></TR><TR><TD CLASS="l">44</TD><TD> </TD></TR><TR><TD CLASS="l">45</TD><TD>/**</TD></TR><TR><TD CLASS="l">46</TD><TD> * An implementation of &lt;code&gt;IProcessorInvoker&lt;/code&gt; that uses JAXP as the underlying</TD></TR><TR><TD CLASS="l">47</TD><TD> * transformation mechanism.</TD></TR><TR><TD CLASS="l">48</TD><TD> * </TD></TR><TR><TD CLASS="l"><A NAME="0">49</A></TD><TD> * @author Doug Satchwell</TD></TR><TR><TD CLASS="l">50</TD><TD> */</TD></TR><TR CLASS="z"><TD CLASS="l">51</TD><TD>public class JAXPSAXProcessorInvoker implements IProcessorInvoker</TD></TR><TR><TD CLASS="l">52</TD><TD>{</TD></TR><TR CLASS="z"><TD CLASS="l">53</TD><TD>        private static final Log log = LogFactory.getLog(JAXPSAXProcessorInvoker.class);</TD></TR><TR><TD CLASS="l">54</TD><TD> </TD></TR><TR><TD CLASS="l">55</TD><TD>        private XMLReader reader;</TD></TR><TR><TD CLASS="l">56</TD><TD>        private SAXTransformerFactory tFactory;</TD></TR><TR><TD CLASS="l">57</TD><TD>        private TransformerHandler th;</TD></TR><TR><TD CLASS="l">58</TD><TD> </TD></TR><TR><TD CLASS="l">59</TD><TD>        /**</TD></TR><TR><TD CLASS="l">60</TD><TD>         * Create a new instance of this.</TD></TR><TR><TD CLASS="l"><A NAME="2">61</A></TD><TD>         * </TD></TR><TR><TD CLASS="l">62</TD><TD>         * @throws SAXException if errors occur while creating an &lt;code&gt;XMLReader&lt;/code&gt;</TD></TR><TR><TD CLASS="l">63</TD><TD>         * @throws ParserConfigurationException if errors occur while creating an &lt;code&gt;XMLReader&lt;/code&gt;</TD></TR><TR><TD CLASS="l">64</TD><TD>         */</TD></TR><TR CLASS="z"><TD CLASS="l">65</TD><TD>        public JAXPSAXProcessorInvoker() throws SAXException, ParserConfigurationException</TD></TR><TR><TD CLASS="l">66</TD><TD>        {</TD></TR><TR CLASS="z"><TD CLASS="l">67</TD><TD>                reader = createReader();</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="5">68</A></TD><TD>        }</TD></TR><TR><TD CLASS="l">69</TD><TD> </TD></TR><TR><TD CLASS="l">70</TD><TD>        protected XMLReader createReader() throws SAXException, ParserConfigurationException</TD></TR><TR><TD CLASS="l">71</TD><TD>        {</TD></TR><TR CLASS="z"><TD CLASS="l">72</TD><TD>                SAXParserFactory spf = SAXParserFactory.newInstance();</TD></TR><TR CLASS="z"><TD CLASS="l">73</TD><TD>                spf.setNamespaceAware(true);</TD></TR><TR CLASS="z"><TD CLASS="l">74</TD><TD>                return spf.newSAXParser().getXMLReader();</TD></TR><TR><TD CLASS="l"><A NAME="7">75</A></TD><TD>        }</TD></TR><TR><TD CLASS="l">76</TD><TD> </TD></TR><TR><TD CLASS="l">77</TD><TD>        public void setAttributes(Map attributes) throws TransformerFactoryConfigurationError</TD></TR><TR><TD CLASS="l">78</TD><TD>        {</TD></TR><TR CLASS="z"><TD CLASS="l">79</TD><TD>                createTransformerFactory();</TD></TR><TR CLASS="z"><TD CLASS="l">80</TD><TD>                for (Iterator iter = attributes.entrySet().iterator(); iter.hasNext();)</TD></TR><TR><TD CLASS="l">81</TD><TD>                {</TD></TR><TR CLASS="z"><TD CLASS="l">82</TD><TD>                        Map.Entry entry = (Map.Entry) iter.next();</TD></TR><TR CLASS="z"><TD CLASS="l">83</TD><TD>                        String uri = (String) entry.getKey();</TD></TR><TR CLASS="z"><TD CLASS="l">84</TD><TD>                        Object value = entry.getValue();</TD></TR><TR CLASS="z"><TD CLASS="l">85</TD><TD>                        log.info(Messages.getString(&#34;JAXPSAXProcessorInvoker.0&#34;) + uri + Messages.getString(&#34;JAXPSAXProcessorInvoker.1&#34;) + value); //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR CLASS="z"><TD CLASS="l">86</TD><TD>                        tFactory.setAttribute(uri, value);</TD></TR><TR><TD CLASS="l">87</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="6">88</A></TD><TD>        }</TD></TR><TR><TD CLASS="l"><A NAME="a">89</A></TD><TD> </TD></TR><TR><TD CLASS="l">90</TD><TD>        protected TransformerFactory createTransformerFactory()</TD></TR><TR><TD CLASS="l">91</TD><TD>        {</TD></TR><TR CLASS="z"><TD CLASS="l">92</TD><TD>                tFactory = (SAXTransformerFactory) TransformerFactory.newInstance();</TD></TR><TR CLASS="z"><TD CLASS="l">93</TD><TD>                tFactory.setErrorListener(new ErrorListener()</TD></TR><TR><TD CLASS="l"><A NAME="c">94</A></TD><TD>                {</TD></TR><TR><TD CLASS="l">95</TD><TD> </TD></TR><TR><TD CLASS="l">96</TD><TD>                        public void error(TransformerException exception) throws TransformerException</TD></TR><TR><TD CLASS="l">97</TD><TD>                        {</TD></TR><TR CLASS="z"><TD CLASS="l">98</TD><TD>                                log.error(exception.getMessageAndLocation());</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="d">99</A></TD><TD>                        }</TD></TR><TR><TD CLASS="l">100</TD><TD> </TD></TR><TR><TD CLASS="l">101</TD><TD>                        public void fatalError(TransformerException exception) throws TransformerException</TD></TR><TR><TD CLASS="l">102</TD><TD>                        {</TD></TR><TR CLASS="z"><TD CLASS="l">103</TD><TD>                                log.error(exception.getMessageAndLocation(), exception);</TD></TR><TR CLASS="z"><TD CLASS="l">104</TD><TD>                                throw exception;</TD></TR><TR><TD CLASS="l"><A NAME="e">105</A></TD><TD>                        }</TD></TR><TR><TD CLASS="l">106</TD><TD> </TD></TR><TR><TD CLASS="l">107</TD><TD>                        public void warning(TransformerException exception) throws TransformerException</TD></TR><TR><TD CLASS="l">108</TD><TD>                        {</TD></TR><TR CLASS="z"><TD CLASS="l">109</TD><TD>                                log.warn(exception.getMessageAndLocation());</TD></TR><TR CLASS="z"><TD CLASS="l">110</TD><TD>                        }</TD></TR><TR><TD CLASS="l">111</TD><TD> </TD></TR><TR><TD CLASS="l">112</TD><TD>                });</TD></TR><TR CLASS="z"><TD CLASS="l">113</TD><TD>                return tFactory;</TD></TR><TR><TD CLASS="l"><A NAME="4">114</A></TD><TD>        }</TD></TR><TR><TD CLASS="l">115</TD><TD> </TD></TR><TR><TD CLASS="l">116</TD><TD>        public void addStylesheet(URL stylesheet, Map parameters, Properties outputProperties, URIResolver resolver) throws TransformerConfigurationException</TD></TR><TR><TD CLASS="l">117</TD><TD>        {</TD></TR><TR CLASS="z"><TD CLASS="l">118</TD><TD>                InputSource inputsource = new InputSource(stylesheet.toString());</TD></TR><TR><TD CLASS="l">119</TD><TD> </TD></TR><TR><TD CLASS="l">120</TD><TD>                // TODO parse document with linenumbers</TD></TR><TR><TD CLASS="l">121</TD><TD> </TD></TR><TR><TD CLASS="l">122</TD><TD>                // XMLReader reader = createReader();</TD></TR><TR><TD CLASS="l">123</TD><TD>                // LineReadingContentHandler ch = new LineReadingContentHandler();</TD></TR><TR><TD CLASS="l">124</TD><TD>                // reader.setContentHandler(ch);</TD></TR><TR CLASS="z"><TD CLASS="l">125</TD><TD>                SAXSource source = new SAXSource(inputsource);</TD></TR><TR><TD CLASS="l">126</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">127</TD><TD>                addStylesheet(source, resolver, parameters, outputProperties);</TD></TR><TR><TD CLASS="l">128</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="3">129</A></TD><TD>        }</TD></TR><TR><TD CLASS="l">130</TD><TD> </TD></TR><TR><TD CLASS="l">131</TD><TD>        protected Transformer addStylesheet(Source source, URIResolver resolver, Map parameters, Properties outputProperties) throws TransformerConfigurationException</TD></TR><TR><TD CLASS="l">132</TD><TD>        {</TD></TR><TR CLASS="z"><TD CLASS="l">133</TD><TD>                if (tFactory == null)</TD></TR><TR CLASS="z"><TD CLASS="l">134</TD><TD>                        createTransformerFactory();</TD></TR><TR><TD CLASS="l">135</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">136</TD><TD>                TransformerHandler newTh = tFactory.newTransformerHandler(source);</TD></TR><TR CLASS="z"><TD CLASS="l">137</TD><TD>                Transformer transformer = newTh.getTransformer();</TD></TR><TR><TD CLASS="l">138</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">139</TD><TD>                if (resolver != null)</TD></TR><TR CLASS="z"><TD CLASS="l">140</TD><TD>                        transformer.setURIResolver(resolver);</TD></TR><TR><TD CLASS="l">141</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">142</TD><TD>                if (parameters != null)</TD></TR><TR><TD CLASS="l">143</TD><TD>                {</TD></TR><TR CLASS="z"><TD CLASS="l">144</TD><TD>                        for (Iterator iter = parameters.entrySet().iterator(); iter.hasNext();)</TD></TR><TR><TD CLASS="l">145</TD><TD>                        {</TD></TR><TR CLASS="z"><TD CLASS="l">146</TD><TD>                                Map.Entry entry = (Map.Entry) iter.next();</TD></TR><TR CLASS="z"><TD CLASS="l">147</TD><TD>                                String name = (String) entry.getKey();</TD></TR><TR CLASS="z"><TD CLASS="l">148</TD><TD>                                Object value = entry.getValue();</TD></TR><TR CLASS="z"><TD CLASS="l">149</TD><TD>                                log.info(Messages.getString(&#34;JAXPSAXProcessorInvoker.2&#34;) + name + Messages.getString(&#34;JAXPSAXProcessorInvoker.3&#34;) + value); //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR CLASS="z"><TD CLASS="l">150</TD><TD>                                transformer.setParameter(name, value);</TD></TR><TR><TD CLASS="l">151</TD><TD>                        }</TD></TR><TR><TD CLASS="l">152</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">153</TD><TD>                if (outputProperties != null)</TD></TR><TR><TD CLASS="l">154</TD><TD>                {</TD></TR><TR CLASS="z"><TD CLASS="l">155</TD><TD>                        StringBuffer sb = new StringBuffer();</TD></TR><TR CLASS="z"><TD CLASS="l">156</TD><TD>                        for (Iterator iter = outputProperties.entrySet().iterator(); iter.hasNext();)</TD></TR><TR><TD CLASS="l">157</TD><TD>                        {</TD></TR><TR CLASS="z"><TD CLASS="l">158</TD><TD>                                Map.Entry entry = (Map.Entry) iter.next();</TD></TR><TR CLASS="z"><TD CLASS="l">159</TD><TD>                                sb.append(entry.getKey()).append(&#34;=&#34;).append(entry.getValue()).append(&#34; &#34;); //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR><TD CLASS="l">160</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">161</TD><TD>                        if (outputProperties.size() &gt; 0)</TD></TR><TR><TD CLASS="l">162</TD><TD>                        {</TD></TR><TR CLASS="z"><TD CLASS="l">163</TD><TD>                                log.info(Messages.getString(&#34;JAXPSAXProcessorInvoker.6&#34;) + sb.toString()); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">164</TD><TD>                                transformer.setOutputProperties(outputProperties);</TD></TR><TR><TD CLASS="l">165</TD><TD>                        }</TD></TR><TR><TD CLASS="l">166</TD><TD>                }</TD></TR><TR><TD CLASS="l">167</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">168</TD><TD>                if (th != null)</TD></TR><TR CLASS="z"><TD CLASS="l">169</TD><TD>                        th.setResult(new SAXResult(newTh));</TD></TR><TR><TD CLASS="l">170</TD><TD>                else {</TD></TR><TR CLASS="z"><TD CLASS="l">171</TD><TD>                        reader.setContentHandler(newTh);</TD></TR><TR><TD CLASS="l">172</TD><TD>                        try {</TD></TR><TR CLASS="z"><TD CLASS="l">173</TD><TD>                                reader.setProperty(&#34;http://xml.org/sax/properties/lexical-handler&#34;, newTh);</TD></TR><TR CLASS="z"><TD CLASS="l">174</TD><TD>                        } catch (SAXNotRecognizedException ex) {</TD></TR><TR CLASS="z"><TD CLASS="l">175</TD><TD>                                log.warn(&#34;Unable to set lexical content handler.  Comments and Processing instructions may be skipped&#34;);</TD></TR><TR CLASS="z"><TD CLASS="l">176</TD><TD>                        } catch (SAXNotSupportedException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">177</TD><TD>                                log.warn(&#34;Lexical property not supported.  Comments and Processing instructions may be skipped&#34;);</TD></TR><TR><TD CLASS="l">178</TD><TD>                        }</TD></TR><TR><TD CLASS="l">179</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">180</TD><TD>                th = newTh;</TD></TR><TR CLASS="z"><TD CLASS="l">181</TD><TD>                return th.getTransformer();</TD></TR><TR><TD CLASS="l"><A NAME="9">182</A></TD><TD>        }</TD></TR><TR><TD CLASS="l">183</TD><TD> </TD></TR><TR><TD CLASS="l">184</TD><TD>        public void transform(URL sourceURL, Result res) throws TransformationException</TD></TR><TR><TD CLASS="l">185</TD><TD>        {</TD></TR><TR CLASS="z"><TD CLASS="l">186</TD><TD>                transform(new InputSource(sourceURL.toExternalForm()), res);</TD></TR><TR CLASS="z"><TD CLASS="l">187</TD><TD>        }</TD></TR><TR><TD CLASS="l">188</TD><TD> </TD></TR><TR><TD CLASS="l">189</TD><TD>        /**</TD></TR><TR><TD CLASS="l">190</TD><TD>         * Transform using an InputSource rather than a URL</TD></TR><TR><TD CLASS="l">191</TD><TD>         * </TD></TR><TR><TD CLASS="l">192</TD><TD>         * @param inputsource the InputSource to use</TD></TR><TR><TD CLASS="l">193</TD><TD>         * @param res the Result</TD></TR><TR><TD CLASS="l">194</TD><TD>         * @throws TransformationException if an error occurred during transformation</TD></TR><TR><TD CLASS="l">195</TD><TD>         */</TD></TR><TR><TD CLASS="l"><A NAME="8">196</A></TD><TD>        public void transform(InputSource inputsource, Result res) throws TransformationException</TD></TR><TR><TD CLASS="l">197</TD><TD>        {</TD></TR><TR><TD CLASS="l">198</TD><TD>                try</TD></TR><TR><TD CLASS="l">199</TD><TD>                {</TD></TR><TR CLASS="z"><TD CLASS="l">200</TD><TD>                        if (th == null)</TD></TR><TR><TD CLASS="l">201</TD><TD>                        {// no stylesheets have been added, so try to use embedded...</TD></TR><TR CLASS="z"><TD CLASS="l">202</TD><TD>                                SAXSource saxSource = new SAXSource(inputsource);</TD></TR><TR CLASS="z"><TD CLASS="l">203</TD><TD>                                Source src = saxSource;</TD></TR><TR CLASS="z"><TD CLASS="l">204</TD><TD>                                String media = null, title = null, charset = null;</TD></TR><TR><TD CLASS="l">205</TD><TD>                                while (true)</TD></TR><TR><TD CLASS="l">206</TD><TD>                                {</TD></TR><TR CLASS="z"><TD CLASS="l">207</TD><TD>                                        src = tFactory.getAssociatedStylesheet(src, media, title, charset);</TD></TR><TR CLASS="z"><TD CLASS="l">208</TD><TD>                                        if (src != null)</TD></TR><TR><TD CLASS="l">209</TD><TD>                                        {</TD></TR><TR CLASS="z"><TD CLASS="l">210</TD><TD>                                                addStylesheet(saxSource, null, Collections.EMPTY_MAP, new Properties());</TD></TR><TR><TD CLASS="l">211</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">212</TD><TD>                                        else</TD></TR><TR><TD CLASS="l">213</TD><TD>                                        {</TD></TR><TR CLASS="z"><TD CLASS="l">214</TD><TD>                                                throw new TransformationException(Messages.getString(&#34;JAXPSAXProcessorInvoker.7&#34;) + inputsource.getSystemId()); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">215</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">216</TD><TD>                                }</TD></TR><TR><TD CLASS="l">217</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">218</TD><TD>                        th.setResult(res);</TD></TR><TR CLASS="z"><TD CLASS="l">219</TD><TD>                        log.info(Messages.getString(&#34;JAXPSAXProcessorInvoker.8&#34;)); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">220</TD><TD>                        reader.parse(inputsource);</TD></TR><TR CLASS="z"><TD CLASS="l">221</TD><TD>                        log.info(Messages.getString(&#34;JAXPSAXProcessorInvoker.9&#34;)); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">222</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">223</TD><TD>                catch (Exception e)</TD></TR><TR><TD CLASS="l">224</TD><TD>                {</TD></TR><TR CLASS="z"><TD CLASS="l">225</TD><TD>                        throw new TransformationException(e.getMessage(), e);</TD></TR><TR><TD CLASS="l">226</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">227</TD><TD>        }</TD></TR><TR><TD CLASS="l">228</TD><TD>}</TD></TR></TABLE><P></P><TABLE CLASS="hdft" CELLSPACING="0" WIDTH="100%"><TR><TD CLASS="nv">[<A HREF="../xslUnitTestCoverage.html">all classes</A>][<A HREF="57.html">org.eclipse.wst.xsl.jaxp.debug.invoker.internal</A>]</TD></TR><TR><TD CLASS="tl"><A HREF="http://www.eclemma.org/support.html">EMMA 2.0.5312 EclEmma Fix 1</A> (C) Vladimir Roubtsov</TD></TR></TABLE></BODY></HTML>