blob: 9f934e8c2838bfe14f304bc4355c663c6b6e96b0 [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="bb.html">org.eclipse.wst.xml.core.internal.parser</A>]</TD></TR></TABLE><H2>COVERAGE SUMMARY FOR SOURCE FILE [<SPAN CLASS="in">XMLSourceParser.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>XMLSourceParser.java</TD><TD>100% (1/1)</TD><TD CLASS="h">28%  (9/32)</TD><TD CLASS="h">13%  (126/1007)</TD><TD CLASS="h">16%  (39.4/242)</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">XMLSourceParser</A></TD><TD>100% (1/1)</TD><TD CLASS="h">28%  (9/32)</TD><TD CLASS="h">13%  (126/1007)</TD><TD CLASS="h">16%  (39.4/242)</TD></TR><TR><TD CLASS="f"><A HREF="#1">_countNodes (IStructuredDocumentRegion): int</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/13)</TD><TD CLASS="h">0%   (0/6)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#2">addBlockMarker (BlockMarker): 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="#3">addStructuredDocumentRegionHandler (StructuredDocumentRegionHandler): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/14)</TD><TD CLASS="h">0%   (0/4)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#4">beginBlockScan (String): 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="#5">getBlockMarkers (): List</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/4)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#6">getRegions (): List</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/17)</TD><TD CLASS="h">0%   (0/6)</TD></TR><TR><TD CLASS="f"><A HREF="#7">getRegions (IStructuredDocumentRegion): List</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/31)</TD><TD CLASS="h">0%   (0/8)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#8">getStructuredDocumentRegionHandlers (): List</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/12)</TD><TD CLASS="h">0%   (0/3)</TD></TR><TR><TD CLASS="f"><A HREF="#9">getText (int, int): String</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/65)</TD><TD CLASS="h">0%   (0/13)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#a">newInstance (): RegionParser</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/11)</TD><TD CLASS="h">0%   (0/3)</TD></TR><TR><TD CLASS="f"><A HREF="#b">parseNodes (): IStructuredDocumentRegion</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/404)</TD><TD CLASS="h">0%   (0/80)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#c">regionMatches (int, int, String): boolean</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/54)</TD><TD CLASS="h">0%   (0/12)</TD></TR><TR><TD CLASS="f"><A HREF="#d">regionMatchesIgnoreCase (int, int, String): boolean</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/54)</TD><TD CLASS="h">0%   (0/12)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#e">removeBlockMarker (BlockMarker): 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="#f">removeBlockMarker (String): 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 CLASS="o"><TD CLASS="f"><A HREF="#10">removeStructuredDocumentRegionHandler (StructuredDocumentRegionHandler): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/15)</TD><TD CLASS="h">0%   (0/5)</TD></TR><TR><TD CLASS="f"><A HREF="#11">reset (FileInputStream): 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 CLASS="o"><TD CLASS="f"><A HREF="#12">reset (Reader): 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="#13">reset (String): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/10)</TD><TD CLASS="h">0%   (0/3)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#14">reset (String, int): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/13)</TD><TD CLASS="h">0%   (0/4)</TD></TR><TR><TD CLASS="f"><A HREF="#15">resetHandlers (): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/21)</TD><TD CLASS="h">0%   (0/5)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#16">setStructuredDocumentRegionHandlers (List): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/4)</TD><TD CLASS="h">0%   (0/2)</TD></TR><TR><TD CLASS="f"><A HREF="#17">setTokenizer (BlockTokenizer): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/4)</TD><TD CLASS="h">0%   (0/2)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#18">getNextRegion (): ITextRegion</A></TD><TD> </TD><TD>100% (1/1)</TD><TD CLASS="h">15%  (8/53)</TD><TD CLASS="h">33%  (3/9)</TD></TR><TR><TD CLASS="f"><A HREF="#19">getBlockMarker (String): BlockMarker</A></TD><TD> </TD><TD>100% (1/1)</TD><TD CLASS="h">36%  (13/36)</TD><TD CLASS="h">32%  (2.9/9)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#1a">fireNodeParsed (IStructuredDocumentRegion): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD CLASS="h">54%  (15/28)</TD><TD CLASS="h">42%  (2.5/6)</TD></TR><TR><TD CLASS="f"><A HREF="#1b">reset (Reader, int): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD CLASS="h">55%  (22/40)</TD><TD CLASS="h">64%  (7/11)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#1c">createStructuredDocumentRegion (String): IStructuredDocumentRegion</A></TD><TD> </TD><TD>100% (1/1)</TD><TD CLASS="h">71%  (10/14)</TD><TD>80%  (4/5)</TD></TR><TR><TD CLASS="f"><A HREF="#0">XMLSourceParser (): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (20/20)</TD><TD>100% (7/7)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#1e">getDocumentRegions (): IStructuredDocumentRegion</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (9/9)</TD><TD>100% (4/4)</TD></TR><TR><TD CLASS="f"><A HREF="#1f">getTokenizer (): BlockTokenizer</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (11/11)</TD><TD>100% (3/3)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#20">primReset (): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (18/18)</TD><TD>100% (6/6)</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) 2001, 2007 IBM Corporation and others.</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> *     IBM Corporation - initial API and implementation</TD></TR><TR><TD CLASS="l">10</TD><TD> *     Jens Lukowski/Innoopract - initial renaming/restructuring</TD></TR><TR><TD CLASS="l">11</TD><TD> *     </TD></TR><TR><TD CLASS="l">12</TD><TD> *******************************************************************************/</TD></TR><TR><TD CLASS="l">13</TD><TD>package org.eclipse.wst.xml.core.internal.parser;</TD></TR><TR><TD CLASS="l">14</TD><TD> </TD></TR><TR><TD CLASS="l">15</TD><TD> </TD></TR><TR><TD CLASS="l">16</TD><TD> </TD></TR><TR><TD CLASS="l">17</TD><TD>import java.io.StringReader;</TD></TR><TR><TD CLASS="l">18</TD><TD>import java.util.ArrayList;</TD></TR><TR><TD CLASS="l">19</TD><TD>import java.util.List;</TD></TR><TR><TD CLASS="l">20</TD><TD> </TD></TR><TR><TD CLASS="l">21</TD><TD>import org.eclipse.jface.text.BadLocationException;</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.internal.document.DocumentReader;</TD></TR><TR><TD CLASS="l">24</TD><TD>import org.eclipse.wst.sse.core.internal.ltk.parser.BlockMarker;</TD></TR><TR><TD CLASS="l">25</TD><TD>import org.eclipse.wst.sse.core.internal.ltk.parser.BlockTagParser;</TD></TR><TR><TD CLASS="l">26</TD><TD>import org.eclipse.wst.sse.core.internal.ltk.parser.BlockTokenizer;</TD></TR><TR><TD CLASS="l">27</TD><TD>import org.eclipse.wst.sse.core.internal.ltk.parser.RegionParser;</TD></TR><TR><TD CLASS="l">28</TD><TD>import org.eclipse.wst.sse.core.internal.ltk.parser.StructuredDocumentRegionHandler;</TD></TR><TR><TD CLASS="l">29</TD><TD>import org.eclipse.wst.sse.core.internal.ltk.parser.StructuredDocumentRegionParser;</TD></TR><TR><TD CLASS="l">30</TD><TD>import org.eclipse.wst.sse.core.internal.ltk.parser.StructuredDocumentRegionParserExtension;</TD></TR><TR><TD CLASS="l">31</TD><TD>import org.eclipse.wst.sse.core.internal.provisional.text.IStructuredDocumentRegion;</TD></TR><TR><TD CLASS="l">32</TD><TD>import org.eclipse.wst.sse.core.internal.provisional.text.ITextRegion;</TD></TR><TR><TD CLASS="l">33</TD><TD>import org.eclipse.wst.sse.core.internal.provisional.text.ITextRegionContainer;</TD></TR><TR><TD CLASS="l">34</TD><TD>import org.eclipse.wst.sse.core.internal.provisional.text.ITextRegionList;</TD></TR><TR><TD CLASS="l">35</TD><TD>import org.eclipse.wst.sse.core.internal.text.CharSequenceReader;</TD></TR><TR><TD CLASS="l">36</TD><TD>import org.eclipse.wst.sse.core.internal.text.IRegionComparible;</TD></TR><TR><TD CLASS="l">37</TD><TD>import org.eclipse.wst.sse.core.internal.util.Debug;</TD></TR><TR><TD CLASS="l">38</TD><TD>import org.eclipse.wst.xml.core.internal.Logger;</TD></TR><TR><TD CLASS="l">39</TD><TD>import org.eclipse.wst.xml.core.internal.regions.DOMRegionContext;</TD></TR><TR><TD CLASS="l">40</TD><TD> </TD></TR><TR><TD CLASS="l">41</TD><TD> </TD></TR><TR><TD CLASS="l">42</TD><TD>/**</TD></TR><TR><TD CLASS="l">43</TD><TD> * Takes input from the HTMLTokenizer and creates a tag list</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>public class XMLSourceParser implements RegionParser, BlockTagParser, StructuredDocumentRegionParser, IRegionComparible, StructuredDocumentRegionParserExtension {</TD></TR><TR><TD CLASS="l">47</TD><TD>        // made public to aid access from inner classes in hierarchy.</TD></TR><TR><TD CLASS="l">48</TD><TD>        // TODO: in future, figure out how to solve without exposing data.</TD></TR><TR CLASS="c"><TD CLASS="l">49</TD><TD>        public CharSequence fCharSequenceSource = null;</TD></TR><TR><TD CLASS="l">50</TD><TD>        private IDocument fDocumentInput;</TD></TR><TR CLASS="c"><TD CLASS="l">51</TD><TD>        protected int fOffset = 0;</TD></TR><TR><TD CLASS="l">52</TD><TD>        // DMW: 2/12/03. Removed some state data, since not really needed,</TD></TR><TR><TD CLASS="l">53</TD><TD>        // and since it added a lot to overhead (since so many regions are</TD></TR><TR><TD CLASS="l">54</TD><TD>        // created.</TD></TR><TR><TD CLASS="l">55</TD><TD>        // protected IStructuredDocumentRegion fCurrentNode = null;</TD></TR><TR><TD CLASS="l">56</TD><TD>        // protected IStructuredDocumentRegion fNodes = null;</TD></TR><TR><TD CLASS="l">57</TD><TD>        // protected List fRegions = null;</TD></TR><TR><TD CLASS="l">58</TD><TD>        // protected Object fInput = null;</TD></TR><TR CLASS="c"><TD CLASS="l">59</TD><TD>        protected String fStringInput = null;</TD></TR><TR><TD CLASS="l">60</TD><TD>        protected List fStructuredDocumentRegionHandlers;</TD></TR><TR><TD CLASS="l">61</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">62</TD><TD>        protected BlockTokenizer fTokenizer = null;</TD></TR><TR><TD CLASS="l">63</TD><TD>        protected long startTime;</TD></TR><TR><TD CLASS="l">64</TD><TD>        protected long stopTime;</TD></TR><TR><TD CLASS="l">65</TD><TD> </TD></TR><TR><TD CLASS="l"><A NAME="0">66</A></TD><TD>        /**</TD></TR><TR><TD CLASS="l">67</TD><TD>         * HTMLSourceParser constructor comment.</TD></TR><TR><TD CLASS="l">68</TD><TD>         */</TD></TR><TR><TD CLASS="l">69</TD><TD>        public XMLSourceParser() {</TD></TR><TR CLASS="c"><TD CLASS="l">70</TD><TD>                super();</TD></TR><TR CLASS="c"><TD CLASS="l">71</TD><TD>                fStructuredDocumentRegionHandlers = new ArrayList();</TD></TR><TR CLASS="c"><TD CLASS="l">72</TD><TD>        }</TD></TR><TR><TD CLASS="l">73</TD><TD> </TD></TR><TR><TD CLASS="l">74</TD><TD>        /**</TD></TR><TR><TD CLASS="l"><A NAME="1">75</A></TD><TD>         * This is a simple utility to count nodes. Used only for debug</TD></TR><TR><TD CLASS="l">76</TD><TD>         * statements.</TD></TR><TR><TD CLASS="l">77</TD><TD>         */</TD></TR><TR><TD CLASS="l">78</TD><TD>        protected int _countNodes(IStructuredDocumentRegion nodes) {</TD></TR><TR CLASS="z"><TD CLASS="l">79</TD><TD>                int result = 0;</TD></TR><TR CLASS="z"><TD CLASS="l">80</TD><TD>                IStructuredDocumentRegion countNode = nodes;</TD></TR><TR CLASS="z"><TD CLASS="l">81</TD><TD>                while (countNode != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">82</TD><TD>                        result++;</TD></TR><TR CLASS="z"><TD CLASS="l">83</TD><TD>                        countNode = countNode.getNext();</TD></TR><TR><TD CLASS="l">84</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="2">85</A></TD><TD>                return result;</TD></TR><TR><TD CLASS="l">86</TD><TD>        }</TD></TR><TR><TD CLASS="l">87</TD><TD> </TD></TR><TR><TD CLASS="l">88</TD><TD>        public void addBlockMarker(BlockMarker marker) {</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="3">89</A></TD><TD>                getTokenizer().addBlockMarker(marker);</TD></TR><TR CLASS="z"><TD CLASS="l">90</TD><TD>        }</TD></TR><TR><TD CLASS="l">91</TD><TD> </TD></TR><TR><TD CLASS="l">92</TD><TD>        public void addStructuredDocumentRegionHandler(StructuredDocumentRegionHandler handler) {</TD></TR><TR CLASS="z"><TD CLASS="l">93</TD><TD>                if (fStructuredDocumentRegionHandlers == null)</TD></TR><TR CLASS="z"><TD CLASS="l">94</TD><TD>                        fStructuredDocumentRegionHandlers = new ArrayList();</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="4">95</A></TD><TD>                fStructuredDocumentRegionHandlers.add(handler);</TD></TR><TR CLASS="z"><TD CLASS="l">96</TD><TD>        }</TD></TR><TR><TD CLASS="l">97</TD><TD> </TD></TR><TR><TD CLASS="l">98</TD><TD>        public void beginBlockScan(String newTagName) {</TD></TR><TR CLASS="z"><TD CLASS="l">99</TD><TD>                getTokenizer().beginBlockTagScan(newTagName);</TD></TR><TR CLASS="z"><TD CLASS="l">100</TD><TD>        }</TD></TR><TR><TD CLASS="l">101</TD><TD> </TD></TR><TR><TD CLASS="l"><A NAME="1c">102</A></TD><TD>        /**</TD></TR><TR><TD CLASS="l">103</TD><TD>         * @return IStructuredDocumentRegion</TD></TR><TR><TD CLASS="l">104</TD><TD>         */</TD></TR><TR><TD CLASS="l">105</TD><TD>        protected IStructuredDocumentRegion createStructuredDocumentRegion(String type) {</TD></TR><TR CLASS="c"><TD CLASS="l">106</TD><TD>                IStructuredDocumentRegion newNode = null;</TD></TR><TR CLASS="c"><TD CLASS="l">107</TD><TD>                if (type == DOMRegionContext.BLOCK_TEXT)</TD></TR><TR CLASS="z"><TD CLASS="l">108</TD><TD>                        newNode = XMLStructuredRegionFactory.createRegion(XMLStructuredRegionFactory.XML_BLOCK);</TD></TR><TR><TD CLASS="l">109</TD><TD>                else</TD></TR><TR CLASS="c"><TD CLASS="l">110</TD><TD>                        newNode = XMLStructuredRegionFactory.createRegion(XMLStructuredRegionFactory.XML);</TD></TR><TR CLASS="c"><TD CLASS="l">111</TD><TD>                return newNode;</TD></TR><TR><TD CLASS="l">112</TD><TD>        }</TD></TR><TR><TD CLASS="l">113</TD><TD> </TD></TR><TR><TD CLASS="l">114</TD><TD>        protected void fireNodeParsed(IStructuredDocumentRegion fCurrentNode) {</TD></TR><TR><TD CLASS="l">115</TD><TD>                /*</TD></TR><TR><TD CLASS="l">116</TD><TD>                 * Never let an Exceptions from foreign code interfere with completion</TD></TR><TR><TD CLASS="l">117</TD><TD>                 * of parsing. To get an exception here is definitely a program error</TD></TR><TR><TD CLASS="l">118</TD><TD>                 * somewhere, but we can't afford to interrupt the flow of control. or</TD></TR><TR><TD CLASS="l">119</TD><TD>                 * backwards typing can result!</TD></TR><TR><TD CLASS="l"><A NAME="1a">120</A></TD><TD>                 * </TD></TR><TR><TD CLASS="l">121</TD><TD>                 * Protect the user's data above everything.</TD></TR><TR><TD CLASS="l">122</TD><TD>                 */</TD></TR><TR><TD CLASS="l">123</TD><TD>                try {</TD></TR><TR CLASS="c"><TD CLASS="l">124</TD><TD>                        if (fCurrentNode != null &amp;&amp; fStructuredDocumentRegionHandlers != null) {</TD></TR><TR CLASS="p"><TD CLASS="l" TITLE="53% line coverage (9 out of 17 instructions)">125</TD><TD TITLE="53% line coverage (9 out of 17 instructions)">                                for (int i = 0; i &lt; fStructuredDocumentRegionHandlers.size(); i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">126</TD><TD>                                        ((StructuredDocumentRegionHandler) fStructuredDocumentRegionHandlers.get(i)).nodeParsed(fCurrentNode);</TD></TR><TR><TD CLASS="l">127</TD><TD>                                }</TD></TR><TR><TD CLASS="l">128</TD><TD>                        }</TD></TR><TR><TD CLASS="l">129</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">130</TD><TD>                catch (Exception e) {</TD></TR><TR CLASS="z"><TD CLASS="l">131</TD><TD>                    Logger.log(Logger.ERROR, &#34;Error occurred while firing Node Parsed event&#34;, e); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l"><A NAME="19">132</A></TD><TD>                }</TD></TR><TR CLASS="c"><TD CLASS="l">133</TD><TD>        }</TD></TR><TR><TD CLASS="l">134</TD><TD> </TD></TR><TR><TD CLASS="l">135</TD><TD>        public BlockMarker getBlockMarker(String tagName) {</TD></TR><TR CLASS="c"><TD CLASS="l">136</TD><TD>                List markers = getTokenizer().getBlockMarkers();</TD></TR><TR CLASS="p"><TD CLASS="l" TITLE="92% line coverage (11 out of 12 instructions)">137</TD><TD TITLE="92% line coverage (11 out of 12 instructions)">                for (int i = 0; i &lt; markers.size(); i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">138</TD><TD>                        BlockMarker marker = (BlockMarker) markers.get(i);</TD></TR><TR CLASS="z"><TD CLASS="l">139</TD><TD>                        if (marker.isCaseSensitive()) {</TD></TR><TR CLASS="z"><TD CLASS="l">140</TD><TD>                                if (marker.getTagName().equals(tagName))</TD></TR><TR CLASS="z"><TD CLASS="l">141</TD><TD>                                        return marker;</TD></TR><TR><TD CLASS="l">142</TD><TD>                        }</TD></TR><TR><TD CLASS="l">143</TD><TD>                        else {</TD></TR><TR CLASS="z"><TD CLASS="l">144</TD><TD>                                if (marker.getTagName().equalsIgnoreCase(tagName))</TD></TR><TR CLASS="z"><TD CLASS="l">145</TD><TD>                                        return marker;</TD></TR><TR><TD CLASS="l">146</TD><TD>                        }</TD></TR><TR><TD CLASS="l">147</TD><TD>                }</TD></TR><TR CLASS="c"><TD CLASS="l"><A NAME="5">148</A></TD><TD>                return null;</TD></TR><TR><TD CLASS="l">149</TD><TD>        }</TD></TR><TR><TD CLASS="l">150</TD><TD> </TD></TR><TR><TD CLASS="l">151</TD><TD>        public List getBlockMarkers() {</TD></TR><TR CLASS="z"><TD CLASS="l">152</TD><TD>                return getTokenizer().getBlockMarkers();</TD></TR><TR><TD CLASS="l">153</TD><TD>        }</TD></TR><TR><TD CLASS="l">154</TD><TD> </TD></TR><TR><TD CLASS="l"><A NAME="1e">155</A></TD><TD>        /**</TD></TR><TR><TD CLASS="l">156</TD><TD>         * @return IStructuredDocumentRegion</TD></TR><TR><TD CLASS="l">157</TD><TD>         */</TD></TR><TR><TD CLASS="l">158</TD><TD>        public IStructuredDocumentRegion getDocumentRegions() {</TD></TR><TR CLASS="c"><TD CLASS="l">159</TD><TD>                IStructuredDocumentRegion headnode = null;</TD></TR><TR CLASS="c"><TD CLASS="l">160</TD><TD>                if (headnode == null) {</TD></TR><TR><TD CLASS="l">161</TD><TD>                        if (Debug.perfTest) {</TD></TR><TR><TD CLASS="l">162</TD><TD>                                startTime = System.currentTimeMillis();</TD></TR><TR><TD CLASS="l">163</TD><TD>                        }</TD></TR><TR CLASS="c"><TD CLASS="l">164</TD><TD>                        headnode = parseNodes();</TD></TR><TR><TD CLASS="l">165</TD><TD>                        if (Debug.perfTest) {</TD></TR><TR><TD CLASS="l">166</TD><TD>                                stopTime = System.currentTimeMillis();</TD></TR><TR><TD CLASS="l">167</TD><TD>                                System.out.println(&#34; -- creating nodes of IStructuredDocument -- &#34;); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">168</TD><TD>                                System.out.println(&#34; Time parse and init all regions: &#34; + (stopTime - startTime) + &#34; (msecs)&#34;); //$NON-NLS-2$//$NON-NLS-1$</TD></TR><TR><TD CLASS="l">169</TD><TD>                                // System.out.println(&#34; for &#34; + fRegions.size() + &#34;</TD></TR><TR><TD CLASS="l">170</TD><TD>                                // Regions&#34;);//$NON-NLS-2$//$NON-NLS-1$</TD></TR><TR><TD CLASS="l">171</TD><TD>                                System.out.println(&#34;      and &#34; + _countNodes(headnode) + &#34; Nodes&#34;); //$NON-NLS-2$//$NON-NLS-1$</TD></TR><TR><TD CLASS="l">172</TD><TD>                        }</TD></TR><TR><TD CLASS="l">173</TD><TD>                }</TD></TR><TR CLASS="c"><TD CLASS="l"><A NAME="18">174</A></TD><TD>                return headnode;</TD></TR><TR><TD CLASS="l">175</TD><TD>        }</TD></TR><TR><TD CLASS="l">176</TD><TD> </TD></TR><TR><TD CLASS="l">177</TD><TD>        protected ITextRegion getNextRegion() {</TD></TR><TR CLASS="c"><TD CLASS="l">178</TD><TD>                ITextRegion region = null;</TD></TR><TR><TD CLASS="l">179</TD><TD>                try {</TD></TR><TR CLASS="c"><TD CLASS="l">180</TD><TD>                        region = getTokenizer().getNextToken();</TD></TR><TR><TD CLASS="l">181</TD><TD>                        // DMW: 2/12/03 Removed state</TD></TR><TR><TD CLASS="l">182</TD><TD>                        // if (region != null) {</TD></TR><TR><TD CLASS="l">183</TD><TD>                        // fRegions.add(region);</TD></TR><TR><TD CLASS="l">184</TD><TD>                        // }</TD></TR><TR CLASS="c"><TD CLASS="l">185</TD><TD>                        return region;</TD></TR><TR><TD CLASS="l">186</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">187</TD><TD>                catch (StackOverflowError e) {</TD></TR><TR CLASS="z"><TD CLASS="l">188</TD><TD>                        Logger.logException(getClass().getName() + &#34;: input could not be parsed correctly at position &#34; + getTokenizer().getOffset(), e); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">189</TD><TD>                        throw e;</TD></TR><TR><TD CLASS="l">190</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">191</TD><TD>                catch (Exception e) {</TD></TR><TR CLASS="z"><TD CLASS="l">192</TD><TD>                        Logger.logException(getClass().getName() + &#34;: input could not be parsed correctly at position &#34; + getTokenizer().getOffset() + &#34; (&#34; + e.getLocalizedMessage() + &#34;)&#34;, e); //$NON-NLS-3$//$NON-NLS-2$//$NON-NLS-1$</TD></TR><TR><TD CLASS="l">193</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">194</TD><TD>                return null;</TD></TR><TR><TD CLASS="l">195</TD><TD>        }</TD></TR><TR><TD CLASS="l">196</TD><TD> </TD></TR><TR><TD CLASS="l">197</TD><TD>        /**</TD></TR><TR><TD CLASS="l"><A NAME="6">198</A></TD><TD>         * Return the full list of known regions. Typically getNodes should be</TD></TR><TR><TD CLASS="l">199</TD><TD>         * used instead of this method.</TD></TR><TR><TD CLASS="l">200</TD><TD>         */</TD></TR><TR><TD CLASS="l">201</TD><TD>        public List getRegions() {</TD></TR><TR CLASS="z"><TD CLASS="l">202</TD><TD>                IStructuredDocumentRegion headNode = null;</TD></TR><TR CLASS="z"><TD CLASS="l">203</TD><TD>                if (!getTokenizer().isEOF()) {</TD></TR><TR CLASS="z"><TD CLASS="l">204</TD><TD>                        headNode = getDocumentRegions();</TD></TR><TR><TD CLASS="l">205</TD><TD>                        // throw new IllegalStateException(&#34;parsing has not finished&#34;);</TD></TR><TR><TD CLASS="l">206</TD><TD>                }</TD></TR><TR><TD CLASS="l">207</TD><TD>                // for memory recovery, we assume if someone</TD></TR><TR><TD CLASS="l">208</TD><TD>                // requests all regions, we can reset our big</TD></TR><TR><TD CLASS="l">209</TD><TD>                // memory consuming objects</TD></TR><TR><TD CLASS="l">210</TD><TD>                // but the new &#34;getRegions&#34; method is then more expensive.</TD></TR><TR><TD CLASS="l">211</TD><TD>                // I don't think its used much, though.</TD></TR><TR CLASS="z"><TD CLASS="l">212</TD><TD>                List localRegionsList = getRegions(headNode);</TD></TR><TR CLASS="z"><TD CLASS="l">213</TD><TD>                primReset();</TD></TR><TR CLASS="z"><TD CLASS="l">214</TD><TD>                return localRegionsList;</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><TD CLASS="l">218</TD><TD>         * Method getRegions.</TD></TR><TR><TD CLASS="l">219</TD><TD>         * </TD></TR><TR><TD CLASS="l"><A NAME="7">220</A></TD><TD>         * @param headNode</TD></TR><TR><TD CLASS="l">221</TD><TD>         * @return List</TD></TR><TR><TD CLASS="l">222</TD><TD>         */</TD></TR><TR><TD CLASS="l">223</TD><TD>        protected List getRegions(IStructuredDocumentRegion headNode) {</TD></TR><TR CLASS="z"><TD CLASS="l">224</TD><TD>                List allRegions = new ArrayList();</TD></TR><TR CLASS="z"><TD CLASS="l">225</TD><TD>                IStructuredDocumentRegion currentNode = headNode;</TD></TR><TR CLASS="z"><TD CLASS="l">226</TD><TD>                while (currentNode != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">227</TD><TD>                        ITextRegionList nodeRegions = currentNode.getRegions();</TD></TR><TR CLASS="z"><TD CLASS="l">228</TD><TD>                        for (int i = 0; i &lt; nodeRegions.size(); i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">229</TD><TD>                                allRegions.add(nodeRegions.get(i));</TD></TR><TR><TD CLASS="l">230</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">231</TD><TD>                        currentNode = currentNode.getNext();</TD></TR><TR><TD CLASS="l">232</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">233</TD><TD>                return allRegions;</TD></TR><TR><TD CLASS="l">234</TD><TD>        }</TD></TR><TR><TD CLASS="l">235</TD><TD> </TD></TR><TR><TD CLASS="l">236</TD><TD>        /**</TD></TR><TR><TD CLASS="l"><A NAME="8">237</A></TD><TD>         * @deprecated - use the add/remove methods instead</TD></TR><TR><TD CLASS="l">238</TD><TD>         * @return java.util.List</TD></TR><TR><TD CLASS="l">239</TD><TD>         */</TD></TR><TR><TD CLASS="l">240</TD><TD>        public List getStructuredDocumentRegionHandlers() {</TD></TR><TR CLASS="z"><TD CLASS="l">241</TD><TD>                if (fStructuredDocumentRegionHandlers == null) {</TD></TR><TR CLASS="z"><TD CLASS="l">242</TD><TD>                        fStructuredDocumentRegionHandlers = new ArrayList(0);</TD></TR><TR><TD CLASS="l">243</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">244</TD><TD>                return fStructuredDocumentRegionHandlers;</TD></TR><TR><TD CLASS="l">245</TD><TD>        }</TD></TR><TR><TD CLASS="l">246</TD><TD> </TD></TR><TR><TD CLASS="l">247</TD><TD>        /**</TD></TR><TR><TD CLASS="l">248</TD><TD>         * Returns text from the current input. Text is only valid before</TD></TR><TR><TD CLASS="l"><A NAME="9">249</A></TD><TD>         * getNodes() has been called and only when a raw String or DocumentReader</TD></TR><TR><TD CLASS="l">250</TD><TD>         * is given as the input.</TD></TR><TR><TD CLASS="l">251</TD><TD>         */</TD></TR><TR><TD CLASS="l">252</TD><TD>        public String getText(int offset, int length) {</TD></TR><TR CLASS="z"><TD CLASS="l">253</TD><TD>                String text = null;</TD></TR><TR CLASS="z"><TD CLASS="l">254</TD><TD>                if (fCharSequenceSource != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">255</TD><TD>                        int start = fOffset + offset;</TD></TR><TR CLASS="z"><TD CLASS="l">256</TD><TD>                        int end = start + length;</TD></TR><TR CLASS="z"><TD CLASS="l">257</TD><TD>                        text = fCharSequenceSource.subSequence(start, end).toString();</TD></TR><TR><TD CLASS="l">258</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">259</TD><TD>                else if (fDocumentInput != null) {</TD></TR><TR><TD CLASS="l">260</TD><TD>                        try {</TD></TR><TR CLASS="z"><TD CLASS="l">261</TD><TD>                                text = fDocumentInput.get(offset, length);</TD></TR><TR><TD CLASS="l">262</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">263</TD><TD>                        catch (BadLocationException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">264</TD><TD>                                text = &#34;&#34;; //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">265</TD><TD>                        }</TD></TR><TR><TD CLASS="l">266</TD><TD>                }</TD></TR><TR><TD CLASS="l">267</TD><TD>                else {</TD></TR><TR CLASS="z"><TD CLASS="l">268</TD><TD>                        if (fStringInput == null || fStringInput.length() == 0 || offset + length &gt; fStringInput.length() || offset &lt; 0) {</TD></TR><TR CLASS="z"><TD CLASS="l">269</TD><TD>                                text = &#34;&#34;; //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">270</TD><TD>                        }</TD></TR><TR><TD CLASS="l">271</TD><TD>                        else {</TD></TR><TR><TD CLASS="l">272</TD><TD>                                // offset is entirely valid during parsing as the parse</TD></TR><TR><TD CLASS="l">273</TD><TD>                                // numbers haven't been adjusted.</TD></TR><TR CLASS="z"><TD CLASS="l">274</TD><TD>                                text = fStringInput.substring(offset, offset + length);</TD></TR><TR><TD CLASS="l">275</TD><TD>                        }</TD></TR><TR><TD CLASS="l">276</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="1f">277</A></TD><TD>                return text;</TD></TR><TR><TD CLASS="l">278</TD><TD>        }</TD></TR><TR><TD CLASS="l">279</TD><TD> </TD></TR><TR><TD CLASS="l">280</TD><TD>        protected BlockTokenizer getTokenizer() {</TD></TR><TR CLASS="c"><TD CLASS="l">281</TD><TD>                if (fTokenizer == null) {</TD></TR><TR CLASS="c"><TD CLASS="l">282</TD><TD>                        fTokenizer = new XMLTokenizer();</TD></TR><TR><TD CLASS="l">283</TD><TD>                }</TD></TR><TR CLASS="c"><TD CLASS="l">284</TD><TD>                return fTokenizer;</TD></TR><TR><TD CLASS="l"><A NAME="a">285</A></TD><TD>        }</TD></TR><TR><TD CLASS="l">286</TD><TD> </TD></TR><TR><TD CLASS="l">287</TD><TD> </TD></TR><TR><TD CLASS="l">288</TD><TD>        public RegionParser newInstance() {</TD></TR><TR CLASS="z"><TD CLASS="l">289</TD><TD>                XMLSourceParser newInstance = new XMLSourceParser();</TD></TR><TR CLASS="z"><TD CLASS="l">290</TD><TD>                newInstance.setTokenizer(getTokenizer().newInstance());</TD></TR><TR CLASS="z"><TD CLASS="l">291</TD><TD>                return newInstance;</TD></TR><TR><TD CLASS="l">292</TD><TD>        }</TD></TR><TR><TD CLASS="l">293</TD><TD> </TD></TR><TR><TD CLASS="l">294</TD><TD>        protected IStructuredDocumentRegion parseNodes() {</TD></TR><TR><TD CLASS="l"><A NAME="b">295</A></TD><TD>                // regions are initially reported as complete offsets within the</TD></TR><TR><TD CLASS="l">296</TD><TD>                // scanned input</TD></TR><TR><TD CLASS="l">297</TD><TD>                // they are adjusted here to be indexes from the currentNode's start</TD></TR><TR><TD CLASS="l">298</TD><TD>                // offset</TD></TR><TR CLASS="z"><TD CLASS="l">299</TD><TD>                IStructuredDocumentRegion headNode = null;</TD></TR><TR CLASS="z"><TD CLASS="l">300</TD><TD>                IStructuredDocumentRegion lastNode = null;</TD></TR><TR CLASS="z"><TD CLASS="l">301</TD><TD>                ITextRegion region = null;</TD></TR><TR CLASS="z"><TD CLASS="l">302</TD><TD>                IStructuredDocumentRegion currentNode = null;</TD></TR><TR CLASS="z"><TD CLASS="l">303</TD><TD>                String type = null;</TD></TR><TR><TD CLASS="l">304</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">305</TD><TD>                while ((region = getNextRegion()) != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">306</TD><TD>                        type = region.getType();</TD></TR><TR><TD CLASS="l">307</TD><TD>                        // these types (might) demand a IStructuredDocumentRegion for each</TD></TR><TR><TD CLASS="l">308</TD><TD>                        // of them</TD></TR><TR CLASS="z"><TD CLASS="l">309</TD><TD>                        if (type == DOMRegionContext.BLOCK_TEXT) {</TD></TR><TR CLASS="z"><TD CLASS="l">310</TD><TD>                                if (currentNode != null &amp;&amp; currentNode.getLastRegion().getType() == DOMRegionContext.BLOCK_TEXT) {</TD></TR><TR><TD CLASS="l">311</TD><TD>                                        // multiple block texts indicated embedded containers; no</TD></TR><TR><TD CLASS="l">312</TD><TD>                                        // new IStructuredDocumentRegion</TD></TR><TR CLASS="z"><TD CLASS="l">313</TD><TD>                                        currentNode.addRegion(region);</TD></TR><TR CLASS="z"><TD CLASS="l">314</TD><TD>                                        currentNode.setLength(region.getStart() + region.getLength() - currentNode.getStart());</TD></TR><TR CLASS="z"><TD CLASS="l">315</TD><TD>                                        region.adjustStart(-currentNode.getStart());</TD></TR><TR><TD CLASS="l">316</TD><TD>                                        // DW 4/16/2003 regions no longer have parents</TD></TR><TR><TD CLASS="l">317</TD><TD>                                        // region.setParent(currentNode);</TD></TR><TR><TD CLASS="l">318</TD><TD>                                }</TD></TR><TR><TD CLASS="l">319</TD><TD>                                else {</TD></TR><TR><TD CLASS="l">320</TD><TD>                                        // not continuing a IStructuredDocumentRegion</TD></TR><TR CLASS="z"><TD CLASS="l">321</TD><TD>                                        if (currentNode != null) {</TD></TR><TR><TD CLASS="l">322</TD><TD>                                                // ensure that any existing node is at least</TD></TR><TR><TD CLASS="l">323</TD><TD>                                                // terminated</TD></TR><TR CLASS="z"><TD CLASS="l">324</TD><TD>                                                if (!currentNode.isEnded()) {</TD></TR><TR CLASS="z"><TD CLASS="l">325</TD><TD>                                                        currentNode.setLength(region.getStart() - currentNode.getStart());</TD></TR><TR><TD CLASS="l">326</TD><TD>                                                        // fCurrentNode.setTextLength(region.getStart() -</TD></TR><TR><TD CLASS="l">327</TD><TD>                                                        // fCurrentNode.getStart());</TD></TR><TR><TD CLASS="l">328</TD><TD>                                                }</TD></TR><TR CLASS="z"><TD CLASS="l">329</TD><TD>                                                lastNode = currentNode;</TD></TR><TR><TD CLASS="l">330</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">331</TD><TD>                                        fireNodeParsed(currentNode);</TD></TR><TR CLASS="z"><TD CLASS="l">332</TD><TD>                                        currentNode = createStructuredDocumentRegion(type);</TD></TR><TR CLASS="z"><TD CLASS="l">333</TD><TD>                                        if (lastNode != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">334</TD><TD>                                                lastNode.setNext(currentNode);</TD></TR><TR><TD CLASS="l">335</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">336</TD><TD>                                        currentNode.setPrevious(lastNode);</TD></TR><TR CLASS="z"><TD CLASS="l">337</TD><TD>                                        currentNode.setStart(region.getStart());</TD></TR><TR CLASS="z"><TD CLASS="l">338</TD><TD>                                        currentNode.setLength(region.getStart() + region.getLength() - currentNode.getStart());</TD></TR><TR CLASS="z"><TD CLASS="l">339</TD><TD>                                        currentNode.setEnded(true);</TD></TR><TR CLASS="z"><TD CLASS="l">340</TD><TD>                                        region.adjustStart(-currentNode.getStart());</TD></TR><TR CLASS="z"><TD CLASS="l">341</TD><TD>                                        currentNode.addRegion(region);</TD></TR><TR><TD CLASS="l">342</TD><TD>                                        // DW 4/16/2003 regions no longer have parents</TD></TR><TR><TD CLASS="l">343</TD><TD>                                        // region.setParent(currentNode);</TD></TR><TR><TD CLASS="l">344</TD><TD>                                }</TD></TR><TR><TD CLASS="l">345</TD><TD>                        }</TD></TR><TR><TD CLASS="l">346</TD><TD>                        // the following contexts OPEN new StructuredDocumentRegions</TD></TR><TR CLASS="z"><TD CLASS="l">347</TD><TD>                        else if ((currentNode != null &amp;&amp; currentNode.isEnded()) || (type == DOMRegionContext.XML_CONTENT) || (type == DOMRegionContext.XML_CHAR_REFERENCE) || (type == DOMRegionContext.XML_ENTITY_REFERENCE) || (type == DOMRegionContext.XML_PI_OPEN) || (type == DOMRegionContext.XML_TAG_OPEN) || (type == DOMRegionContext.XML_END_TAG_OPEN) || (type == DOMRegionContext.XML_COMMENT_OPEN) || (type == DOMRegionContext.XML_CDATA_OPEN) || (type == DOMRegionContext.XML_DECLARATION_OPEN)) {</TD></TR><TR CLASS="z"><TD CLASS="l">348</TD><TD>                                if (currentNode != null) {</TD></TR><TR><TD CLASS="l">349</TD><TD>                                        // ensure that any existing node is at least terminated</TD></TR><TR CLASS="z"><TD CLASS="l">350</TD><TD>                                        if (!currentNode.isEnded()) {</TD></TR><TR CLASS="z"><TD CLASS="l">351</TD><TD>                                                currentNode.setLength(region.getStart() - currentNode.getStart());</TD></TR><TR><TD CLASS="l">352</TD><TD>                                                // fCurrentNode.setTextLength(region.getStart() -</TD></TR><TR><TD CLASS="l">353</TD><TD>                                                // fCurrentNode.getStart());</TD></TR><TR><TD CLASS="l">354</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">355</TD><TD>                                        lastNode = currentNode;</TD></TR><TR><TD CLASS="l">356</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">357</TD><TD>                                fireNodeParsed(currentNode);</TD></TR><TR CLASS="z"><TD CLASS="l">358</TD><TD>                                currentNode = createStructuredDocumentRegion(type);</TD></TR><TR CLASS="z"><TD CLASS="l">359</TD><TD>                                if (lastNode != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">360</TD><TD>                                        lastNode.setNext(currentNode);</TD></TR><TR><TD CLASS="l">361</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">362</TD><TD>                                currentNode.setPrevious(lastNode);</TD></TR><TR CLASS="z"><TD CLASS="l">363</TD><TD>                                currentNode.setStart(region.getStart());</TD></TR><TR CLASS="z"><TD CLASS="l">364</TD><TD>                                currentNode.addRegion(region);</TD></TR><TR CLASS="z"><TD CLASS="l">365</TD><TD>                                currentNode.setLength(region.getStart() + region.getLength() - currentNode.getStart());</TD></TR><TR CLASS="z"><TD CLASS="l">366</TD><TD>                                region.adjustStart(-currentNode.getStart());</TD></TR><TR><TD CLASS="l">367</TD><TD>                                // DW 4/16/2003 regions no longer have parents</TD></TR><TR><TD CLASS="l">368</TD><TD>                                // region.setParent(currentNode);</TD></TR><TR><TD CLASS="l">369</TD><TD>                        }</TD></TR><TR><TD CLASS="l">370</TD><TD>                        // the following contexts neither open nor close</TD></TR><TR><TD CLASS="l">371</TD><TD>                        // StructuredDocumentRegions; just add to them</TD></TR><TR CLASS="z"><TD CLASS="l">372</TD><TD>                        else if ((type == DOMRegionContext.XML_TAG_NAME) || (type == DOMRegionContext.XML_TAG_ATTRIBUTE_NAME) || (type == DOMRegionContext.XML_TAG_ATTRIBUTE_EQUALS) || (type == DOMRegionContext.XML_TAG_ATTRIBUTE_VALUE) || (type == DOMRegionContext.XML_COMMENT_TEXT) || (type == DOMRegionContext.XML_PI_CONTENT) || (type == DOMRegionContext.XML_DOCTYPE_INTERNAL_SUBSET)) {</TD></TR><TR CLASS="z"><TD CLASS="l">373</TD><TD>                                currentNode.addRegion(region);</TD></TR><TR CLASS="z"><TD CLASS="l">374</TD><TD>                                currentNode.setLength(region.getStart() + region.getLength() - currentNode.getStart());</TD></TR><TR CLASS="z"><TD CLASS="l">375</TD><TD>                                region.adjustStart(-currentNode.getStart());</TD></TR><TR><TD CLASS="l">376</TD><TD>                                // DW 4/16/2003 regions no longer have parents</TD></TR><TR><TD CLASS="l">377</TD><TD>                                // region.setParent(currentNode);</TD></TR><TR><TD CLASS="l">378</TD><TD>                        }</TD></TR><TR><TD CLASS="l">379</TD><TD>                        // the following contexts close off StructuredDocumentRegions</TD></TR><TR><TD CLASS="l">380</TD><TD>                        // cleanly</TD></TR><TR CLASS="z"><TD CLASS="l">381</TD><TD>                        else if ((type == DOMRegionContext.XML_PI_CLOSE) || (type == DOMRegionContext.XML_TAG_CLOSE) || (type == DOMRegionContext.XML_EMPTY_TAG_CLOSE) || (type == DOMRegionContext.XML_COMMENT_CLOSE) || (type == DOMRegionContext.XML_DECLARATION_CLOSE) || (type == DOMRegionContext.XML_CDATA_CLOSE)) {</TD></TR><TR CLASS="z"><TD CLASS="l">382</TD><TD>                                currentNode.setEnded(true);</TD></TR><TR CLASS="z"><TD CLASS="l">383</TD><TD>                                currentNode.setLength(region.getStart() + region.getLength() - currentNode.getStart());</TD></TR><TR CLASS="z"><TD CLASS="l">384</TD><TD>                                currentNode.addRegion(region);</TD></TR><TR CLASS="z"><TD CLASS="l">385</TD><TD>                                region.adjustStart(-currentNode.getStart());</TD></TR><TR><TD CLASS="l">386</TD><TD>                                // DW 4/16/2003 regions no longer have parents</TD></TR><TR><TD CLASS="l">387</TD><TD>                                // region.setParent(currentNode);</TD></TR><TR><TD CLASS="l">388</TD><TD>                        }</TD></TR><TR><TD CLASS="l">389</TD><TD>                        // this is extremely rare, but valid</TD></TR><TR CLASS="z"><TD CLASS="l">390</TD><TD>                        else if (type == DOMRegionContext.WHITE_SPACE) {</TD></TR><TR CLASS="z"><TD CLASS="l">391</TD><TD>                                ITextRegion lastRegion = currentNode.getLastRegion();</TD></TR><TR><TD CLASS="l">392</TD><TD>                                // pack the embedded container with this region</TD></TR><TR CLASS="z"><TD CLASS="l">393</TD><TD>                                if (lastRegion instanceof ITextRegionContainer) {</TD></TR><TR CLASS="z"><TD CLASS="l">394</TD><TD>                                        ITextRegionContainer container = (ITextRegionContainer) lastRegion;</TD></TR><TR CLASS="z"><TD CLASS="l">395</TD><TD>                                        container.getRegions().add(region);</TD></TR><TR><TD CLASS="l">396</TD><TD>                                        // containers must have parent set ...</TD></TR><TR><TD CLASS="l">397</TD><TD>                                        // setting for EACH subregion is redundent, but not sure</TD></TR><TR><TD CLASS="l">398</TD><TD>                                        // where else to do, so will do here for now.</TD></TR><TR CLASS="z"><TD CLASS="l">399</TD><TD>                                        container.setParent(currentNode);</TD></TR><TR><TD CLASS="l">400</TD><TD>                                        // DW 4/16/2003 regions no longer have parents</TD></TR><TR><TD CLASS="l">401</TD><TD>                                        // region.setParent(container);</TD></TR><TR CLASS="z"><TD CLASS="l">402</TD><TD>                                        region.adjustStart(container.getLength() - region.getStart());</TD></TR><TR><TD CLASS="l">403</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">404</TD><TD>                                currentNode.getLastRegion().adjustLength(region.getLength());</TD></TR><TR CLASS="z"><TD CLASS="l">405</TD><TD>                                currentNode.adjustLength(region.getLength());</TD></TR><TR><TD CLASS="l">406</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">407</TD><TD>                        else if (type == DOMRegionContext.UNDEFINED &amp;&amp; currentNode != null) {</TD></TR><TR><TD CLASS="l">408</TD><TD>                                // skip on a very-first region situation as the default</TD></TR><TR><TD CLASS="l">409</TD><TD>                                // behavior is good enough</TD></TR><TR><TD CLASS="l">410</TD><TD>                                // combine with previous if also undefined</TD></TR><TR CLASS="z"><TD CLASS="l">411</TD><TD>                                if (currentNode.getLastRegion() != null &amp;&amp; currentNode.getLastRegion().getType() == DOMRegionContext.UNDEFINED) {</TD></TR><TR CLASS="z"><TD CLASS="l">412</TD><TD>                                        currentNode.getLastRegion().adjustLength(region.getLength());</TD></TR><TR CLASS="z"><TD CLASS="l">413</TD><TD>                                        currentNode.adjustLength(region.getLength());</TD></TR><TR><TD CLASS="l">414</TD><TD>                                }</TD></TR><TR><TD CLASS="l">415</TD><TD>                                // previous wasn't undefined</TD></TR><TR><TD CLASS="l">416</TD><TD>                                else {</TD></TR><TR CLASS="z"><TD CLASS="l">417</TD><TD>                                        currentNode.addRegion(region);</TD></TR><TR CLASS="z"><TD CLASS="l">418</TD><TD>                                        currentNode.setLength(region.getStart() + region.getLength() - currentNode.getStart());</TD></TR><TR CLASS="z"><TD CLASS="l">419</TD><TD>                                        region.adjustStart(-currentNode.getStart());</TD></TR><TR><TD CLASS="l">420</TD><TD>                                }</TD></TR><TR><TD CLASS="l">421</TD><TD>                        }</TD></TR><TR><TD CLASS="l">422</TD><TD>                        else {</TD></TR><TR><TD CLASS="l">423</TD><TD>                                // if an unknown type is the first region in the document,</TD></TR><TR><TD CLASS="l">424</TD><TD>                                // ensure that a node exists</TD></TR><TR CLASS="z"><TD CLASS="l">425</TD><TD>                                if (currentNode == null) {</TD></TR><TR CLASS="z"><TD CLASS="l">426</TD><TD>                                        currentNode = createStructuredDocumentRegion(type);</TD></TR><TR CLASS="z"><TD CLASS="l">427</TD><TD>                                        currentNode.setStart(region.getStart());</TD></TR><TR><TD CLASS="l">428</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">429</TD><TD>                                currentNode.addRegion(region);</TD></TR><TR CLASS="z"><TD CLASS="l">430</TD><TD>                                currentNode.setLength(region.getStart() + region.getLength() - currentNode.getStart());</TD></TR><TR CLASS="z"><TD CLASS="l">431</TD><TD>                                region.adjustStart(-currentNode.getStart());</TD></TR><TR><TD CLASS="l">432</TD><TD>                                // DW 4/16/2003 regions no longer have parents</TD></TR><TR><TD CLASS="l">433</TD><TD>                                // region.setParent(currentNode);</TD></TR><TR><TD CLASS="l">434</TD><TD>                                if (Debug.debugTokenizer)</TD></TR><TR><TD CLASS="l">435</TD><TD>                                        System.out.println(getClass().getName() + &#34; found region of not specifically handled type &#34; + region.getType() + &#34; @ &#34; + region.getStart() + &#34;[&#34; + region.getLength() + &#34;]&#34;); //$NON-NLS-4$//$NON-NLS-3$//$NON-NLS-2$//$NON-NLS-1$</TD></TR><TR><TD CLASS="l">436</TD><TD>                                //$NON-NLS-3$//$NON-NLS-2$//$NON-NLS-1$</TD></TR><TR><TD CLASS="l">437</TD><TD>                        }</TD></TR><TR><TD CLASS="l">438</TD><TD> </TD></TR><TR><TD CLASS="l">439</TD><TD>                        // these regions also get their own node, so close them cleanly</TD></TR><TR><TD CLASS="l">440</TD><TD>                        // NOTE: these regions have new StructuredDocumentRegions created</TD></TR><TR><TD CLASS="l">441</TD><TD>                        // for them above; it may</TD></TR><TR><TD CLASS="l">442</TD><TD>                        // be more readable if that is handled here as well, but the</TD></TR><TR><TD CLASS="l">443</TD><TD>                        // current layout</TD></TR><TR><TD CLASS="l">444</TD><TD>                        // ensures that they open StructuredDocumentRegions the same way</TD></TR><TR CLASS="z"><TD CLASS="l">445</TD><TD>                        if ((type == DOMRegionContext.XML_CONTENT) || (type == DOMRegionContext.XML_CHAR_REFERENCE) || (type == DOMRegionContext.XML_ENTITY_REFERENCE)) {</TD></TR><TR CLASS="z"><TD CLASS="l">446</TD><TD>                                currentNode.setEnded(true);</TD></TR><TR><TD CLASS="l">447</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">448</TD><TD>                        if (headNode == null &amp;&amp; currentNode != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">449</TD><TD>                                headNode = currentNode;</TD></TR><TR><TD CLASS="l">450</TD><TD>                        }</TD></TR><TR><TD CLASS="l">451</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">452</TD><TD>                if (currentNode != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">453</TD><TD>                        fireNodeParsed(currentNode);</TD></TR><TR CLASS="z"><TD CLASS="l">454</TD><TD>                        currentNode.setPrevious(lastNode);</TD></TR><TR><TD CLASS="l">455</TD><TD>                }</TD></TR><TR><TD CLASS="l">456</TD><TD>                // fStringInput = null;</TD></TR><TR CLASS="z"><TD CLASS="l">457</TD><TD>                primReset();</TD></TR><TR CLASS="z"><TD CLASS="l">458</TD><TD>                return headNode;</TD></TR><TR><TD CLASS="l">459</TD><TD>        }</TD></TR><TR><TD CLASS="l">460</TD><TD> </TD></TR><TR><TD CLASS="l"><A NAME="20">461</A></TD><TD>        protected void primReset() {</TD></TR><TR><TD CLASS="l">462</TD><TD>                // fNodes = null;</TD></TR><TR><TD CLASS="l">463</TD><TD>                // fRegions = null;</TD></TR><TR><TD CLASS="l">464</TD><TD>                // fInput = null;</TD></TR><TR CLASS="c"><TD CLASS="l">465</TD><TD>                fStringInput = null;</TD></TR><TR CLASS="c"><TD CLASS="l">466</TD><TD>                fCharSequenceSource = null;</TD></TR><TR CLASS="c"><TD CLASS="l">467</TD><TD>                fDocumentInput = null;</TD></TR><TR CLASS="c"><TD CLASS="l">468</TD><TD>                fOffset = 0;</TD></TR><TR><TD CLASS="l">469</TD><TD>                // fCurrentNode = null;</TD></TR><TR><TD CLASS="l">470</TD><TD>                // DMW: also reset tokenizer so it doesn't hold on</TD></TR><TR><TD CLASS="l">471</TD><TD>                // to large arrays</TD></TR><TR CLASS="c"><TD CLASS="l">472</TD><TD>                getTokenizer().reset(new char[0]);</TD></TR><TR CLASS="c"><TD CLASS="l">473</TD><TD>        }</TD></TR><TR><TD CLASS="l">474</TD><TD> </TD></TR><TR><TD CLASS="l">475</TD><TD>        /*</TD></TR><TR><TD CLASS="l">476</TD><TD>         * (non-Javadoc)</TD></TR><TR><TD CLASS="l">477</TD><TD>         * </TD></TR><TR><TD CLASS="l">478</TD><TD>         * @see org.eclipse.wst.sse.core.internal.text.IRegionComparible#regionMatches(int,</TD></TR><TR><TD CLASS="l"><A NAME="c">479</A></TD><TD>         *      int, java.lang.String)</TD></TR><TR><TD CLASS="l">480</TD><TD>         */</TD></TR><TR><TD CLASS="l">481</TD><TD>        public boolean regionMatches(int offset, int length, String stringToCompare) {</TD></TR><TR><TD CLASS="l">482</TD><TD>                // by definition</TD></TR><TR CLASS="z"><TD CLASS="l">483</TD><TD>                if (stringToCompare == null)</TD></TR><TR CLASS="z"><TD CLASS="l">484</TD><TD>                        return false;</TD></TR><TR><TD CLASS="l">485</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">486</TD><TD>                boolean result = false;</TD></TR><TR CLASS="z"><TD CLASS="l">487</TD><TD>                if (fCharSequenceSource != null &amp;&amp; fCharSequenceSource instanceof IRegionComparible) {</TD></TR><TR CLASS="z"><TD CLASS="l">488</TD><TD>                        result = ((IRegionComparible) fCharSequenceSource).regionMatches(offset, length, stringToCompare);</TD></TR><TR><TD CLASS="l">489</TD><TD>                }</TD></TR><TR><TD CLASS="l">490</TD><TD>                else {</TD></TR><TR><TD CLASS="l">491</TD><TD>                        // old fashioned ways</TD></TR><TR CLASS="z"><TD CLASS="l">492</TD><TD>                        String test = null;</TD></TR><TR CLASS="z"><TD CLASS="l">493</TD><TD>                        if (fCharSequenceSource != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">494</TD><TD>                                test = fCharSequenceSource.subSequence(offset, offset + length).toString();</TD></TR><TR><TD CLASS="l">495</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">496</TD><TD>                        else if (fStringInput != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">497</TD><TD>                                test = fStringInput.substring(offset, offset + length);</TD></TR><TR><TD CLASS="l">498</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">499</TD><TD>                        result = stringToCompare.equals(test);</TD></TR><TR><TD CLASS="l">500</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">501</TD><TD>                return result;</TD></TR><TR><TD CLASS="l"><A NAME="d">502</A></TD><TD>        }</TD></TR><TR><TD CLASS="l">503</TD><TD> </TD></TR><TR><TD CLASS="l">504</TD><TD>        public boolean regionMatchesIgnoreCase(int offset, int length, String stringToCompare) {</TD></TR><TR><TD CLASS="l">505</TD><TD>                // by definition</TD></TR><TR CLASS="z"><TD CLASS="l">506</TD><TD>                if (stringToCompare == null)</TD></TR><TR CLASS="z"><TD CLASS="l">507</TD><TD>                        return false;</TD></TR><TR><TD CLASS="l">508</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">509</TD><TD>                boolean result = false;</TD></TR><TR CLASS="z"><TD CLASS="l">510</TD><TD>                if (fCharSequenceSource != null &amp;&amp; fCharSequenceSource instanceof IRegionComparible) {</TD></TR><TR CLASS="z"><TD CLASS="l">511</TD><TD>                        result = ((IRegionComparible) fCharSequenceSource).regionMatchesIgnoreCase(offset, length, stringToCompare);</TD></TR><TR><TD CLASS="l">512</TD><TD>                }</TD></TR><TR><TD CLASS="l">513</TD><TD>                else {</TD></TR><TR><TD CLASS="l">514</TD><TD>                        // old fashioned ways</TD></TR><TR CLASS="z"><TD CLASS="l">515</TD><TD>                        String test = null;</TD></TR><TR CLASS="z"><TD CLASS="l">516</TD><TD>                        if (fCharSequenceSource != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">517</TD><TD>                                test = fCharSequenceSource.subSequence(offset, offset + length).toString();</TD></TR><TR><TD CLASS="l">518</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">519</TD><TD>                        else if (fStringInput != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">520</TD><TD>                                test = fStringInput.substring(offset, offset + length);</TD></TR><TR><TD CLASS="l">521</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">522</TD><TD>                        result = stringToCompare.equalsIgnoreCase(test);</TD></TR><TR><TD CLASS="l">523</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="e">524</A></TD><TD>                return result;</TD></TR><TR><TD CLASS="l">525</TD><TD>        }</TD></TR><TR><TD CLASS="l">526</TD><TD> </TD></TR><TR><TD CLASS="l">527</TD><TD>        public void removeBlockMarker(BlockMarker marker) {</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="f">528</A></TD><TD>                getTokenizer().removeBlockMarker(marker);</TD></TR><TR CLASS="z"><TD CLASS="l">529</TD><TD>        }</TD></TR><TR><TD CLASS="l">530</TD><TD> </TD></TR><TR><TD CLASS="l">531</TD><TD>        public void removeBlockMarker(String tagName) {</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="10">532</A></TD><TD>                getTokenizer().removeBlockMarker(tagName);</TD></TR><TR CLASS="z"><TD CLASS="l">533</TD><TD>        }</TD></TR><TR><TD CLASS="l">534</TD><TD> </TD></TR><TR><TD CLASS="l">535</TD><TD>        public void removeStructuredDocumentRegionHandler(StructuredDocumentRegionHandler handler) {</TD></TR><TR CLASS="z"><TD CLASS="l">536</TD><TD>                if (fStructuredDocumentRegionHandlers == null)</TD></TR><TR CLASS="z"><TD CLASS="l">537</TD><TD>                        return;</TD></TR><TR CLASS="z"><TD CLASS="l">538</TD><TD>                if (fStructuredDocumentRegionHandlers.contains(handler))</TD></TR><TR CLASS="z"><TD CLASS="l">539</TD><TD>                        fStructuredDocumentRegionHandlers.remove(handler);</TD></TR><TR CLASS="z"><TD CLASS="l">540</TD><TD>        }</TD></TR><TR><TD CLASS="l">541</TD><TD> </TD></TR><TR><TD CLASS="l"><A NAME="11">542</A></TD><TD>        /**</TD></TR><TR><TD CLASS="l">543</TD><TD>         * Resets the input.</TD></TR><TR><TD CLASS="l">544</TD><TD>         */</TD></TR><TR><TD CLASS="l">545</TD><TD>        public void reset(java.io.FileInputStream instream) {</TD></TR><TR CLASS="z"><TD CLASS="l">546</TD><TD>                primReset();</TD></TR><TR><TD CLASS="l">547</TD><TD>                // fInput = instream;</TD></TR><TR CLASS="z"><TD CLASS="l">548</TD><TD>                getTokenizer().reset(instream);</TD></TR><TR CLASS="z"><TD CLASS="l">549</TD><TD>        }</TD></TR><TR><TD CLASS="l">550</TD><TD> </TD></TR><TR><TD CLASS="l"><A NAME="12">551</A></TD><TD>        /**</TD></TR><TR><TD CLASS="l">552</TD><TD>         * Resets the input.</TD></TR><TR><TD CLASS="l">553</TD><TD>         */</TD></TR><TR><TD CLASS="l">554</TD><TD>        public void reset(java.io.Reader reader) {</TD></TR><TR CLASS="z"><TD CLASS="l">555</TD><TD>                reset(reader, 0);</TD></TR><TR CLASS="z"><TD CLASS="l">556</TD><TD>        }</TD></TR><TR><TD CLASS="l">557</TD><TD> </TD></TR><TR><TD CLASS="l"><A NAME="1b">558</A></TD><TD>        /**</TD></TR><TR><TD CLASS="l">559</TD><TD>         * Resets the input.</TD></TR><TR><TD CLASS="l">560</TD><TD>         */</TD></TR><TR><TD CLASS="l">561</TD><TD>        public void reset(java.io.Reader reader, int position) {</TD></TR><TR CLASS="c"><TD CLASS="l">562</TD><TD>                primReset();</TD></TR><TR CLASS="c"><TD CLASS="l">563</TD><TD>                fOffset = position;</TD></TR><TR CLASS="c"><TD CLASS="l">564</TD><TD>                getTokenizer().reset(reader, position);</TD></TR><TR CLASS="c"><TD CLASS="l">565</TD><TD>                if (reader instanceof DocumentReader) {</TD></TR><TR CLASS="z"><TD CLASS="l">566</TD><TD>                        IDocument doc = ((DocumentReader) reader).getDocument();</TD></TR><TR CLASS="z"><TD CLASS="l">567</TD><TD>                        if (doc instanceof CharSequence) {</TD></TR><TR CLASS="z"><TD CLASS="l">568</TD><TD>                                fCharSequenceSource = (CharSequence) doc;</TD></TR><TR><TD CLASS="l">569</TD><TD>                        }</TD></TR><TR><TD CLASS="l">570</TD><TD>                        else {</TD></TR><TR><TD CLASS="l">571</TD><TD>                                // old fashioned IDocument</TD></TR><TR CLASS="z"><TD CLASS="l">572</TD><TD>                                fDocumentInput = ((DocumentReader) reader).getDocument();</TD></TR><TR><TD CLASS="l">573</TD><TD>                        }</TD></TR><TR><TD CLASS="l">574</TD><TD> </TD></TR><TR><TD CLASS="l">575</TD><TD>                }</TD></TR><TR CLASS="c"><TD CLASS="l">576</TD><TD>                else if (reader instanceof CharSequenceReader) {</TD></TR><TR CLASS="c"><TD CLASS="l">577</TD><TD>                        fCharSequenceSource = ((CharSequenceReader) reader).getOriginalSource();</TD></TR><TR><TD CLASS="l">578</TD><TD>                }</TD></TR><TR CLASS="c"><TD CLASS="l">579</TD><TD>        }</TD></TR><TR><TD CLASS="l">580</TD><TD> </TD></TR><TR><TD CLASS="l">581</TD><TD>        /**</TD></TR><TR><TD CLASS="l">582</TD><TD>         * Resets the input. Use this version to allow text to be retrieved</TD></TR><TR><TD CLASS="l"><A NAME="13">583</A></TD><TD>         * &lt;em&gt;during&lt;/em&gt; parsing, such as by the</TD></TR><TR><TD CLASS="l">584</TD><TD>         * StructuredDocumentRegionHandler.</TD></TR><TR><TD CLASS="l">585</TD><TD>         */</TD></TR><TR><TD CLASS="l">586</TD><TD>        public void reset(String sourceString) {</TD></TR><TR CLASS="z"><TD CLASS="l">587</TD><TD>                reset(new StringReader(sourceString));</TD></TR><TR CLASS="z"><TD CLASS="l">588</TD><TD>                fStringInput = sourceString;</TD></TR><TR CLASS="z"><TD CLASS="l">589</TD><TD>        }</TD></TR><TR><TD CLASS="l">590</TD><TD> </TD></TR><TR><TD CLASS="l">591</TD><TD>        /**</TD></TR><TR><TD CLASS="l">592</TD><TD>         * Resets the input. Use this version to allow text to be retrieved</TD></TR><TR><TD CLASS="l"><A NAME="14">593</A></TD><TD>         * &lt;em&gt;during&lt;/em&gt; parsing, such as by the</TD></TR><TR><TD CLASS="l">594</TD><TD>         * StructuredDocumentRegionHandler.</TD></TR><TR><TD CLASS="l">595</TD><TD>         */</TD></TR><TR><TD CLASS="l">596</TD><TD>        public void reset(String sourceString, int position) {</TD></TR><TR CLASS="z"><TD CLASS="l">597</TD><TD>                StringReader reader = new StringReader(sourceString);</TD></TR><TR CLASS="z"><TD CLASS="l">598</TD><TD>                reset(reader, position);</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="15">599</A></TD><TD>                fStringInput = sourceString;</TD></TR><TR CLASS="z"><TD CLASS="l">600</TD><TD>        }</TD></TR><TR><TD CLASS="l">601</TD><TD> </TD></TR><TR><TD CLASS="l">602</TD><TD>        public void resetHandlers() {</TD></TR><TR CLASS="z"><TD CLASS="l">603</TD><TD>                if (fStructuredDocumentRegionHandlers != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">604</TD><TD>                        int size = fStructuredDocumentRegionHandlers.size();</TD></TR><TR CLASS="z"><TD CLASS="l">605</TD><TD>                        for (int i = 0; i &lt; size; i++)</TD></TR><TR CLASS="z"><TD CLASS="l">606</TD><TD>                                ((StructuredDocumentRegionHandler) fStructuredDocumentRegionHandlers.get(i)).resetNodes();</TD></TR><TR><TD CLASS="l">607</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">608</TD><TD>        }</TD></TR><TR><TD CLASS="l">609</TD><TD> </TD></TR><TR><TD CLASS="l">610</TD><TD>        /**</TD></TR><TR><TD CLASS="l"><A NAME="16">611</A></TD><TD>         * </TD></TR><TR><TD CLASS="l">612</TD><TD>         * @param List</TD></TR><TR><TD CLASS="l">613</TD><TD>         */</TD></TR><TR><TD CLASS="l">614</TD><TD>        public void setStructuredDocumentRegionHandlers(List newStructuredDocumentRegionHandlers) {</TD></TR><TR CLASS="z"><TD CLASS="l">615</TD><TD>                fStructuredDocumentRegionHandlers = newStructuredDocumentRegionHandlers;</TD></TR><TR CLASS="z"><TD CLASS="l">616</TD><TD>        }</TD></TR><TR><TD CLASS="l"><A NAME="17">617</A></TD><TD> </TD></TR><TR><TD CLASS="l">618</TD><TD>        protected void setTokenizer(BlockTokenizer newTokenizer) {</TD></TR><TR><TD CLASS="l">619</TD><TD>                // DMW: changed from private to protected, so subclass could use in</TD></TR><TR><TD CLASS="l">620</TD><TD>                // creation of 'newInstance'.</TD></TR><TR CLASS="z"><TD CLASS="l">621</TD><TD>                fTokenizer = newTokenizer;</TD></TR><TR CLASS="z"><TD CLASS="l">622</TD><TD>        }</TD></TR><TR><TD CLASS="l">623</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="bb.html">org.eclipse.wst.xml.core.internal.parser</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>