blob: e2d6177308cf9a9a614670e103d169709f3ea83a [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="c4.html">org.eclipse.wst.xsl.core</A>]</TD></TR></TABLE><H2>COVERAGE SUMMARY FOR SOURCE FILE [<SPAN CLASS="in">XSLCore.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>XSLCore.java</TD><TD>100% (1/1)</TD><TD>83%  (10/12)</TD><TD CLASS="h">75%  (156/209)</TD><TD CLASS="h">72%  (38.8/54)</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">XSLCore</A></TD><TD>100% (1/1)</TD><TD>83%  (10/12)</TD><TD CLASS="h">75%  (156/209)</TD><TD CLASS="h">72%  (38.8/54)</TD></TR><TR><TD CLASS="f"><A HREF="#1">clean (IProject, IProgressMonitor): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/25)</TD><TD CLASS="h">0%   (0/5)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#2">isXMLFile (IFile): boolean</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/3)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR><TD CLASS="f"><A HREF="#3">getCurrentNode (IDocument, int): Node</A></TD><TD> </TD><TD>100% (1/1)</TD><TD CLASS="h">60%  (24/40)</TD><TD CLASS="h">61%  (7.9/13)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#4">resolveFile (IFile, String): IFile</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>85%  (23/27)</TD><TD CLASS="h">67%  (4/6)</TD></TR><TR><TD CLASS="f"><A HREF="#5">buildStylesheet (IFile): StylesheetModel</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>92%  (22/24)</TD><TD>86%  (6/7)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#6">getCurrentAttrNode (Node, int): Attr</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>92%  (35/38)</TD><TD>84%  (5.9/7)</TD></TR><TR><TD CLASS="f"><A HREF="#0">XSLCore (): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (8/8)</TD><TD>100% (3/3)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#8">getInstance (): XSLCore</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (8/8)</TD><TD>100% (3/3)</TD></TR><TR><TD CLASS="f"><A HREF="#9">getStylesheet (IFile): StylesheetModel</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (14/14)</TD><TD>100% (4/4)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#a">hasNamespace (Node): boolean</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (9/9)</TD><TD>100% (1/1)</TD></TR><TR><TD CLASS="f"><A HREF="#b">isXSLFile (IFile): boolean</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (3/3)</TD><TD>100% (1/1)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#c">isXSLNamespace (Node): boolean</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (10/10)</TD><TD>100% (3/3)</TD></TR></TABLE><P></P><TABLE CLASS="s" CELLSPACING="0" WIDTH="100%"><TR><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.core;</TD></TR><TR><TD CLASS="l">12</TD><TD> </TD></TR><TR><TD CLASS="l">13</TD><TD>import java.util.HashMap;</TD></TR><TR><TD CLASS="l">14</TD><TD>import java.util.Iterator;</TD></TR><TR><TD CLASS="l">15</TD><TD>import java.util.Map;</TD></TR><TR><TD CLASS="l">16</TD><TD> </TD></TR><TR><TD CLASS="l">17</TD><TD>import org.eclipse.core.resources.IFile;</TD></TR><TR><TD CLASS="l">18</TD><TD>import org.eclipse.core.resources.IProject;</TD></TR><TR><TD CLASS="l">19</TD><TD>import org.eclipse.core.resources.IResource;</TD></TR><TR><TD CLASS="l">20</TD><TD>import org.eclipse.core.runtime.IProgressMonitor;</TD></TR><TR><TD CLASS="l">21</TD><TD>import org.eclipse.core.runtime.Path;</TD></TR><TR><TD CLASS="l">22</TD><TD>import org.eclipse.jface.text.IDocument;</TD></TR><TR><TD CLASS="l">23</TD><TD>import org.eclipse.wst.sse.core.StructuredModelManager;</TD></TR><TR><TD CLASS="l">24</TD><TD>import org.eclipse.wst.sse.core.internal.provisional.IStructuredModel;</TD></TR><TR><TD CLASS="l">25</TD><TD>import org.eclipse.wst.sse.core.internal.provisional.IndexedRegion;</TD></TR><TR><TD CLASS="l">26</TD><TD>import org.eclipse.wst.xml.core.internal.provisional.document.IDOMNode;</TD></TR><TR><TD CLASS="l">27</TD><TD>import org.eclipse.wst.xsl.core.internal.StylesheetBuilder;</TD></TR><TR><TD CLASS="l">28</TD><TD>import org.eclipse.wst.xsl.core.internal.util.FileUtil;</TD></TR><TR><TD CLASS="l">29</TD><TD>import org.eclipse.wst.xsl.core.model.Stylesheet;</TD></TR><TR><TD CLASS="l">30</TD><TD>import org.eclipse.wst.xsl.core.model.StylesheetModel;</TD></TR><TR><TD CLASS="l">31</TD><TD>import org.w3c.dom.Attr;</TD></TR><TR><TD CLASS="l">32</TD><TD>import org.w3c.dom.NamedNodeMap;</TD></TR><TR><TD CLASS="l">33</TD><TD>import org.w3c.dom.Node;</TD></TR><TR><TD CLASS="l">34</TD><TD> </TD></TR><TR><TD CLASS="l">35</TD><TD>/**</TD></TR><TR><TD CLASS="l">36</TD><TD> * The interface to all aspects of the XSL core functionality.</TD></TR><TR><TD CLASS="l">37</TD><TD> * &lt;p&gt;</TD></TR><TR><TD CLASS="l">38</TD><TD> * This is responsible for building and maintaining the cache of built XSL models.</TD></TR><TR><TD CLASS="l">39</TD><TD> * &lt;/p&gt;</TD></TR><TR><TD CLASS="l">40</TD><TD> * </TD></TR><TR><TD CLASS="l">41</TD><TD> * @author Doug Satchwell</TD></TR><TR><TD CLASS="l">42</TD><TD> */</TD></TR><TR><TD CLASS="l">43</TD><TD>public class XSLCore</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>         * The XSL namespace URI (= http://www.w3.org/1999/XSL/Transform)</TD></TR><TR><TD CLASS="l">47</TD><TD>         */</TD></TR><TR><TD CLASS="l">48</TD><TD>        public static final String XSL_NAMESPACE_URI = &#34;http://www.w3.org/1999/XSL/Transform&#34;; //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">49</TD><TD>        </TD></TR><TR><TD CLASS="l">50</TD><TD>        /**</TD></TR><TR><TD CLASS="l">51</TD><TD>         * The XSL content type (= org.eclipse.wst.xml.core.xslsource)</TD></TR><TR><TD CLASS="l">52</TD><TD>         */</TD></TR><TR><TD CLASS="l">53</TD><TD>        public static final String XSL_CONTENT_TYPE = &#34;org.eclipse.wst.xml.core.xslsource&#34;; //$NON-NLS-1$</TD></TR><TR><TD CLASS="l"><A NAME="0">54</A></TD><TD>        </TD></TR><TR><TD CLASS="l">55</TD><TD>        private static XSLCore instance;</TD></TR><TR CLASS="c"><TD CLASS="l">56</TD><TD>        private Map&lt;IFile, StylesheetModel&gt; stylesheetsComposed = new HashMap&lt;IFile, StylesheetModel&gt;();</TD></TR><TR><TD CLASS="l">57</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">58</TD><TD>        private XSLCore()</TD></TR><TR CLASS="c"><TD CLASS="l">59</TD><TD>        {}</TD></TR><TR><TD CLASS="l">60</TD><TD> </TD></TR><TR><TD CLASS="l">61</TD><TD>        /**</TD></TR><TR><TD CLASS="l">62</TD><TD>         * Get the cached stylesheet, or build it if it has not yet been built.</TD></TR><TR><TD CLASS="l">63</TD><TD>         * </TD></TR><TR><TD CLASS="l">64</TD><TD>         * @param file</TD></TR><TR><TD CLASS="l">65</TD><TD>         * @return source file, or null if could not be built</TD></TR><TR><TD CLASS="l"><A NAME="9">66</A></TD><TD>         * @since 1.0</TD></TR><TR><TD CLASS="l">67</TD><TD>         */</TD></TR><TR><TD CLASS="l">68</TD><TD>        public synchronized StylesheetModel getStylesheet(IFile file)</TD></TR><TR><TD CLASS="l">69</TD><TD>        {</TD></TR><TR CLASS="c"><TD CLASS="l">70</TD><TD>                StylesheetModel stylesheet = stylesheetsComposed.get(file);</TD></TR><TR CLASS="c"><TD CLASS="l">71</TD><TD>                if (stylesheet == null)</TD></TR><TR CLASS="c"><TD CLASS="l">72</TD><TD>                        stylesheet = buildStylesheet(file);</TD></TR><TR CLASS="c"><TD CLASS="l">73</TD><TD>                return stylesheet;</TD></TR><TR><TD CLASS="l">74</TD><TD>        }</TD></TR><TR><TD CLASS="l">75</TD><TD> </TD></TR><TR><TD CLASS="l">76</TD><TD>        /**</TD></TR><TR><TD CLASS="l">77</TD><TD>         * Completely rebuild the source file from its DOM</TD></TR><TR><TD CLASS="l">78</TD><TD>         * </TD></TR><TR><TD CLASS="l">79</TD><TD>         * @param file</TD></TR><TR><TD CLASS="l">80</TD><TD>         * @return the stylesheet model, or null if it could not be created.</TD></TR><TR><TD CLASS="l"><A NAME="5">81</A></TD><TD>         * @since 1.0</TD></TR><TR><TD CLASS="l">82</TD><TD>         */</TD></TR><TR><TD CLASS="l">83</TD><TD>        public synchronized StylesheetModel buildStylesheet(IFile file)</TD></TR><TR><TD CLASS="l">84</TD><TD>        {</TD></TR><TR CLASS="c"><TD CLASS="l">85</TD><TD>                Stylesheet stylesheet = StylesheetBuilder.getInstance().getStylesheet(file, true);</TD></TR><TR CLASS="c"><TD CLASS="l">86</TD><TD>                if (stylesheet == null)</TD></TR><TR CLASS="z"><TD CLASS="l">87</TD><TD>                        return null;</TD></TR><TR CLASS="c"><TD CLASS="l">88</TD><TD>                StylesheetModel stylesheetComposed = new StylesheetModel(stylesheet);                        </TD></TR><TR CLASS="c"><TD CLASS="l">89</TD><TD>                stylesheetsComposed.put(file, stylesheetComposed);</TD></TR><TR CLASS="c"><TD CLASS="l">90</TD><TD>                stylesheetComposed.fix();</TD></TR><TR CLASS="c"><TD CLASS="l">91</TD><TD>                return stylesheetComposed;</TD></TR><TR><TD CLASS="l">92</TD><TD>        }</TD></TR><TR><TD CLASS="l">93</TD><TD>        </TD></TR><TR><TD CLASS="l">94</TD><TD>        /**</TD></TR><TR><TD CLASS="l">95</TD><TD>         * Clean all of the stylesheets from the given project.</TD></TR><TR><TD CLASS="l">96</TD><TD>         * </TD></TR><TR><TD CLASS="l">97</TD><TD>         * @param project the project to be cleaned</TD></TR><TR><TD CLASS="l"><A NAME="1">98</A></TD><TD>         * @param monitor a progress monitor to track the clean progress</TD></TR><TR><TD CLASS="l">99</TD><TD>         */</TD></TR><TR><TD CLASS="l">100</TD><TD>        public synchronized void clean(IProject project, IProgressMonitor monitor)</TD></TR><TR><TD CLASS="l">101</TD><TD>        {</TD></TR><TR CLASS="z"><TD CLASS="l">102</TD><TD>                for (Iterator&lt;StylesheetModel&gt; iter = stylesheetsComposed.values().iterator(); iter.hasNext();)</TD></TR><TR><TD CLASS="l">103</TD><TD>                {</TD></TR><TR CLASS="z"><TD CLASS="l">104</TD><TD>                        StylesheetModel model = iter.next();</TD></TR><TR CLASS="z"><TD CLASS="l">105</TD><TD>                        if (project == null || project.equals(model.getStylesheet().getFile().getProject()))</TD></TR><TR><TD CLASS="l">106</TD><TD>                        {</TD></TR><TR CLASS="z"><TD CLASS="l">107</TD><TD>                                iter.remove();</TD></TR><TR><TD CLASS="l">108</TD><TD>                        }</TD></TR><TR><TD CLASS="l">109</TD><TD>                }</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><TD CLASS="l">113</TD><TD>         * Get the singleton &lt;code&gt;XSLCore&lt;/code&gt; instance.</TD></TR><TR><TD CLASS="l">114</TD><TD>         * </TD></TR><TR><TD CLASS="l"><A NAME="8">115</A></TD><TD>         * @return the &lt;code&gt;XSLCore&lt;/code&gt; instance</TD></TR><TR><TD CLASS="l">116</TD><TD>         */</TD></TR><TR><TD CLASS="l">117</TD><TD>        public static synchronized XSLCore getInstance()</TD></TR><TR><TD CLASS="l">118</TD><TD>        {</TD></TR><TR CLASS="c"><TD CLASS="l">119</TD><TD>                if (instance == null)</TD></TR><TR CLASS="c"><TD CLASS="l">120</TD><TD>                        instance = new XSLCore();</TD></TR><TR CLASS="c"><TD CLASS="l">121</TD><TD>                return instance;</TD></TR><TR><TD CLASS="l">122</TD><TD>        }</TD></TR><TR><TD CLASS="l">123</TD><TD> </TD></TR><TR><TD CLASS="l">124</TD><TD>        /**</TD></TR><TR><TD CLASS="l">125</TD><TD>         * Locates a file for the given current file and URI.</TD></TR><TR><TD CLASS="l">126</TD><TD>         * </TD></TR><TR><TD CLASS="l">127</TD><TD>         * @param currentFile the file to resolve relative to</TD></TR><TR><TD CLASS="l">128</TD><TD>         * @param uri the relative URI </TD></TR><TR><TD CLASS="l">129</TD><TD>         * @return the file at the URI relative to this &lt;code&gt;currentFile&lt;/code&gt;</TD></TR><TR><TD CLASS="l"><A NAME="4">130</A></TD><TD>         */</TD></TR><TR><TD CLASS="l">131</TD><TD>        // TODO depends on how we resolve URIs                </TD></TR><TR><TD CLASS="l">132</TD><TD>        public static IFile resolveFile(IFile currentFile, String uri)</TD></TR><TR><TD CLASS="l">133</TD><TD>        {</TD></TR><TR CLASS="c"><TD CLASS="l">134</TD><TD>                if (uri == null || uri.trim().length() == 0)</TD></TR><TR CLASS="z"><TD CLASS="l">135</TD><TD>                        return null;</TD></TR><TR CLASS="c"><TD CLASS="l">136</TD><TD>                IResource resource = currentFile.getParent().findMember(new Path(uri));</TD></TR><TR CLASS="c"><TD CLASS="l">137</TD><TD>                if (resource == null || resource.getType() != IResource.FILE)</TD></TR><TR CLASS="z"><TD CLASS="l">138</TD><TD>                        return null;                </TD></TR><TR CLASS="c"><TD CLASS="l">139</TD><TD>                return (IFile)resource;</TD></TR><TR><TD CLASS="l">140</TD><TD>        }</TD></TR><TR><TD CLASS="l">141</TD><TD>        /**</TD></TR><TR><TD CLASS="l">142</TD><TD>         * Determine whether the given file is an XML file by inspecting its content types.</TD></TR><TR><TD CLASS="l">143</TD><TD>         * </TD></TR><TR><TD CLASS="l">144</TD><TD>         * @param file the file to inspect</TD></TR><TR><TD CLASS="l">145</TD><TD>         * @return true if this file is an XML file</TD></TR><TR><TD CLASS="l"><A NAME="2">146</A></TD><TD>         */</TD></TR><TR><TD CLASS="l">147</TD><TD> </TD></TR><TR><TD CLASS="l">148</TD><TD>        public static boolean isXMLFile(IFile file)</TD></TR><TR><TD CLASS="l">149</TD><TD>        {</TD></TR><TR CLASS="z"><TD CLASS="l">150</TD><TD>                return FileUtil.isXMLFile(file);</TD></TR><TR><TD CLASS="l">151</TD><TD>        }</TD></TR><TR><TD CLASS="l">152</TD><TD> </TD></TR><TR><TD CLASS="l">153</TD><TD>        /**</TD></TR><TR><TD CLASS="l">154</TD><TD>         * Determine whether the given file is an XSL file by inspecting its content types.</TD></TR><TR><TD CLASS="l">155</TD><TD>         * </TD></TR><TR><TD CLASS="l">156</TD><TD>         * @param file the file to inspect</TD></TR><TR><TD CLASS="l"><A NAME="b">157</A></TD><TD>         * @return true if this file is an XSL file</TD></TR><TR><TD CLASS="l">158</TD><TD>         */</TD></TR><TR><TD CLASS="l">159</TD><TD>        public static boolean isXSLFile(IFile file)</TD></TR><TR><TD CLASS="l">160</TD><TD>        {</TD></TR><TR CLASS="c"><TD CLASS="l">161</TD><TD>                return FileUtil.isXSLFile(file);</TD></TR><TR><TD CLASS="l">162</TD><TD>        }</TD></TR><TR><TD CLASS="l">163</TD><TD>        </TD></TR><TR><TD CLASS="l">164</TD><TD>        </TD></TR><TR><TD CLASS="l">165</TD><TD>        /**</TD></TR><TR><TD CLASS="l">166</TD><TD>         * Takes a given &lt;code&gt;Node&lt;/code&gt; and returns whether it </TD></TR><TR><TD CLASS="l">167</TD><TD>         * is part of the the XSLT Namespace.</TD></TR><TR><TD CLASS="l">168</TD><TD>         * @param node  The Node to be checked.</TD></TR><TR><TD CLASS="l"><A NAME="c">169</A></TD><TD>         * @return True if part of the XSLT namespace, false otherwise.</TD></TR><TR><TD CLASS="l">170</TD><TD>         * @since 1.0</TD></TR><TR><TD CLASS="l">171</TD><TD>         */</TD></TR><TR><TD CLASS="l">172</TD><TD>        public static boolean isXSLNamespace(Node node) {</TD></TR><TR CLASS="c"><TD CLASS="l">173</TD><TD>                if (hasNamespace(node)) {</TD></TR><TR CLASS="c"><TD CLASS="l">174</TD><TD>                        return false;</TD></TR><TR><TD CLASS="l">175</TD><TD>                }</TD></TR><TR CLASS="c"><TD CLASS="l">176</TD><TD>                return node.getNamespaceURI().equals(XSL_NAMESPACE_URI);</TD></TR><TR><TD CLASS="l">177</TD><TD>        }</TD></TR><TR><TD CLASS="l">178</TD><TD> </TD></TR><TR><TD CLASS="l">179</TD><TD>        /**</TD></TR><TR><TD CLASS="l">180</TD><TD>         * Determine if the Node that was passed has a Namespace.  If it</TD></TR><TR><TD CLASS="l">181</TD><TD>         * doesn't the node is either going to be false, or the call to the</TD></TR><TR><TD CLASS="l">182</TD><TD>         * getNamespace() method will return null.</TD></TR><TR><TD CLASS="l"><A NAME="a">183</A></TD><TD>         * @param node</TD></TR><TR><TD CLASS="l">184</TD><TD>         * @return</TD></TR><TR><TD CLASS="l">185</TD><TD>         */</TD></TR><TR><TD CLASS="l">186</TD><TD>        private static boolean hasNamespace(Node node) {</TD></TR><TR CLASS="c"><TD CLASS="l">187</TD><TD>                return node == null || node.getNamespaceURI() == null;</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>        /**</TD></TR><TR><TD CLASS="l">191</TD><TD>         * Returns an Attr node for the current Node if one exits at the specified offset.</TD></TR><TR><TD CLASS="l">192</TD><TD>         * @param node </TD></TR><TR><TD CLASS="l">193</TD><TD>         * @param offset </TD></TR><TR><TD CLASS="l">194</TD><TD>         * @return A w3c.dom.Attr</TD></TR><TR><TD CLASS="l"><A NAME="6">195</A></TD><TD>         * @since 1.0</TD></TR><TR><TD CLASS="l">196</TD><TD>         */</TD></TR><TR><TD CLASS="l">197</TD><TD>        public static Attr getCurrentAttrNode(Node node, int offset)</TD></TR><TR><TD CLASS="l">198</TD><TD>        {</TD></TR><TR CLASS="c"><TD CLASS="l">199</TD><TD>                if ((node instanceof IndexedRegion) &amp;&amp; ((IndexedRegion) node).contains(offset) &amp;&amp; (node.hasAttributes()))</TD></TR><TR><TD CLASS="l">200</TD><TD>                {</TD></TR><TR CLASS="c"><TD CLASS="l">201</TD><TD>                        NamedNodeMap attrs = node.getAttributes();</TD></TR><TR CLASS="p"><TD CLASS="l" TITLE="91% line coverage (10 out of 11 instructions)">202</TD><TD TITLE="91% line coverage (10 out of 11 instructions)">                        for (int i = 0; i &lt; attrs.getLength(); ++i)</TD></TR><TR><TD CLASS="l">203</TD><TD>                        {</TD></TR><TR CLASS="c"><TD CLASS="l">204</TD><TD>                                IndexedRegion attRegion = (IndexedRegion) attrs.item(i);</TD></TR><TR CLASS="c"><TD CLASS="l">205</TD><TD>                                if (attRegion.contains(offset))</TD></TR><TR><TD CLASS="l">206</TD><TD>                                {</TD></TR><TR CLASS="c"><TD CLASS="l">207</TD><TD>                                        return (Attr) attrs.item(i);</TD></TR><TR><TD CLASS="l">208</TD><TD>                                }</TD></TR><TR><TD CLASS="l">209</TD><TD>                        }</TD></TR><TR><TD CLASS="l">210</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">211</TD><TD>                return null;</TD></TR><TR><TD CLASS="l">212</TD><TD>        }</TD></TR><TR><TD CLASS="l">213</TD><TD> </TD></TR><TR><TD CLASS="l">214</TD><TD>        /**</TD></TR><TR><TD CLASS="l">215</TD><TD>         * Returns the current Node at the specified offset.</TD></TR><TR><TD CLASS="l">216</TD><TD>         * </TD></TR><TR><TD CLASS="l">217</TD><TD>         * @param document </TD></TR><TR><TD CLASS="l">218</TD><TD>         * @param offset </TD></TR><TR><TD CLASS="l">219</TD><TD>         * @return an w3c.dom.Node</TD></TR><TR><TD CLASS="l"><A NAME="3">220</A></TD><TD>         * @since 1.0</TD></TR><TR><TD CLASS="l">221</TD><TD>         */</TD></TR><TR><TD CLASS="l">222</TD><TD>        public static Node getCurrentNode(IDocument document, int offset)</TD></TR><TR><TD CLASS="l">223</TD><TD>        {</TD></TR><TR CLASS="c"><TD CLASS="l">224</TD><TD>                IndexedRegion inode = null;</TD></TR><TR CLASS="c"><TD CLASS="l">225</TD><TD>                IStructuredModel sModel = null;</TD></TR><TR><TD CLASS="l">226</TD><TD>                try</TD></TR><TR><TD CLASS="l">227</TD><TD>                {</TD></TR><TR CLASS="c"><TD CLASS="l">228</TD><TD>                        sModel = StructuredModelManager.getModelManager().getExistingModelForRead(document);</TD></TR><TR CLASS="c"><TD CLASS="l">229</TD><TD>                        inode = sModel.getIndexedRegion(offset);</TD></TR><TR CLASS="c"><TD CLASS="l">230</TD><TD>                        if (inode == null)</TD></TR><TR CLASS="z"><TD CLASS="l">231</TD><TD>                                inode = sModel.getIndexedRegion(offset - 1);</TD></TR><TR><TD CLASS="l">232</TD><TD>                }</TD></TR><TR><TD CLASS="l">233</TD><TD>                finally</TD></TR><TR CLASS="z"><TD CLASS="l">234</TD><TD>                {</TD></TR><TR CLASS="p"><TD CLASS="l" TITLE="40% line coverage (2 out of 5 instructions)">235</TD><TD TITLE="40% line coverage (2 out of 5 instructions)">                        if (sModel != null)</TD></TR><TR CLASS="p"><TD CLASS="l" TITLE="50% line coverage (2 out of 4 instructions)">236</TD><TD TITLE="50% line coverage (2 out of 4 instructions)">                                sModel.releaseFromRead();</TD></TR><TR CLASS="z"><TD CLASS="l">237</TD><TD>                }</TD></TR><TR><TD CLASS="l">238</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">239</TD><TD>                if (inode instanceof Node)</TD></TR><TR><TD CLASS="l">240</TD><TD>                {</TD></TR><TR CLASS="c"><TD CLASS="l">241</TD><TD>                        return (Node) inode;</TD></TR><TR><TD CLASS="l">242</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">243</TD><TD>                return null;</TD></TR><TR><TD CLASS="l">244</TD><TD>        }</TD></TR><TR><TD CLASS="l">245</TD><TD>        </TD></TR><TR><TD CLASS="l">246</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="c4.html">org.eclipse.wst.xsl.core</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>