blob: 81921d0c359b511d6c33e35c7d84f9c3892717a0 [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="ad.html">org.eclipse.wst.sse.ui.internal.reconcile</A>]</TD></TR></TABLE><H2>COVERAGE SUMMARY FOR SOURCE FILE [<SPAN CLASS="in">DirtyRegionProcessor.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>DirtyRegionProcessor.java</TD><TD>100% (4/4)</TD><TD>80%  (35/44)</TD><TD CLASS="h">42%  (449/1065)</TD><TD CLASS="h">49%  (128.7/264)</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">DirtyRegionProcessor$DocumentListener</A></TD><TD>100% (1/1)</TD><TD CLASS="h">25%  (1/4)</TD><TD CLASS="h">4%   (6/168)</TD><TD CLASS="h">3%   (1/34)</TD></TR><TR><TD CLASS="f"><A HREF="#1">documentAboutToBeChanged (DocumentEvent): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/20)</TD><TD CLASS="h">0%   (0/4)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#2">documentChanged (DocumentEvent): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/78)</TD><TD CLASS="h">0%   (0/16)</TD></TR><TR><TD CLASS="f"><A HREF="#3">partitionsChanged (DocumentEvent): boolean</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/64)</TD><TD CLASS="h">0%   (0/13)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#0">DirtyRegionProcessor$DocumentListener (DirtyRegionProcessor): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (6/6)</TD><TD>100% (1/1)</TD></TR><TR><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD></TR><TR CLASS="cis"><TD CLASS="f">class <A HREF="#5">DirtyRegionProcessor$DocumentRewriteSessionListener</A></TD><TD>100% (1/1)</TD><TD CLASS="h">50%  (1/2)</TD><TD CLASS="h">7%   (9/127)</TD><TD CLASS="h">9%   (2/23)</TD></TR><TR><TD CLASS="f"><A HREF="#6">documentRewriteSessionChanged (DocumentRewriteSessionEvent): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/118)</TD><TD CLASS="h">0%   (0/21)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#5">DirtyRegionProcessor$DocumentRewriteSessionListener (DirtyRegionProcessor): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (9/9)</TD><TD>100% (2/2)</TD></TR><TR><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD></TR><TR CLASS="cis"><TD CLASS="f">class <A HREF="#8">DirtyRegionProcessor</A></TD><TD>100% (1/1)</TD><TD>86%  (30/35)</TD><TD CLASS="h">56%  (421/757)</TD><TD CLASS="h">60%  (121.7/203)</TD></TR><TR><TD CLASS="f"><A HREF="#9">getOuterRegion (DirtyRegion, DirtyRegion): DirtyRegion</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/19)</TD><TD CLASS="h">0%   (0/6)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#a">getPartitionRegions (int, int): ITypedRegion []</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/42)</TD><TD CLASS="h">0%   (0/12)</TD></TR><TR><TD CLASS="f"><A HREF="#b">getPartitions (int, int): String []</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/61)</TD><TD CLASS="h">0%   (0/15)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#c">isContained (DirtyRegion, DirtyRegion): boolean</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/26)</TD><TD CLASS="h">0%   (0/7)</TD></TR><TR><TD CLASS="f"><A HREF="#d">setReconcilingStrategy (String, IReconcilingStrategy): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/21)</TD><TD CLASS="h">0%   (0/6)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#e">setEntireDocumentDirty (IDocument): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD CLASS="h">42%  (21/50)</TD><TD CLASS="h">56%  (5.6/10)</TD></TR><TR><TD CLASS="f"><A HREF="#f">processDirtyRegion (DirtyRegion): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD CLASS="h">43%  (18/42)</TD><TD CLASS="h">67%  (6/9)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#10">computePartitioning (int, int): ITypedRegion []</A></TD><TD> </TD><TD>100% (1/1)</TD><TD CLASS="h">45%  (28/62)</TD><TD CLASS="h">50%  (7/14)</TD></TR><TR><TD CLASS="f"><A HREF="#11">addRequest (DirtyRegion): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD CLASS="h">45%  (15/33)</TD><TD CLASS="h">40%  (4/10)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#8">&lt;static initializer&gt;</A></TD><TD> </TD><TD>100% (1/1)</TD><TD CLASS="h">57%  (8/14)</TD><TD>86%  (2.6/3)</TD></TR><TR><TD CLASS="f"><A HREF="#13">createDirtyRegion (int, int, String): DirtyRegion</A></TD><TD> </TD><TD>100% (1/1)</TD><TD CLASS="h">57%  (36/63)</TD><TD CLASS="h">64%  (9/14)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#14">run (IProgressMonitor): IStatus</A></TD><TD> </TD><TD>100% (1/1)</TD><TD CLASS="h">68%  (40/59)</TD><TD CLASS="h">69%  (12.5/18)</TD></TR><TR><TD CLASS="f"><A HREF="#15">getDocumentPartitioning (): String</A></TD><TD> </TD><TD>100% (1/1)</TD><TD CLASS="h">75%  (6/8)</TD><TD CLASS="h">67%  (2/3)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#16">getReconcilingStrategy (String): IReconcilingStrategy</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>80%  (8/10)</TD><TD CLASS="h">67%  (2/3)</TD></TR><TR><TD CLASS="f"><A HREF="#17">process (DirtyRegion): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>81%  (25/31)</TD><TD CLASS="h">75%  (6/8)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#18">DirtyRegionProcessor (): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (60/60)</TD><TD>100% (16/16)</TD></TR><TR><TD CLASS="f"><A HREF="#19">beginProcessing (): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (1/1)</TD><TD>100% (1/1)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#1a">computePartitioning (DirtyRegion): ITypedRegion []</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (11/11)</TD><TD>100% (3/3)</TD></TR><TR><TD CLASS="f"><A HREF="#1b">createDirtyRegion (ITypedRegion, String): DirtyRegion</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (8/8)</TD><TD>100% (1/1)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#1c">endProcessing (): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (1/1)</TD><TD>100% (1/1)</TD></TR><TR><TD CLASS="f"><A HREF="#1d">flushDirtyRegionQueue (): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (4/4)</TD><TD>100% (2/2)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#1e">getDelay (): long</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (3/3)</TD><TD>100% (1/1)</TD></TR><TR><TD CLASS="f"><A HREF="#1f">getDirtyRegionQueue (): List</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="#20">getDocument (): IDocument</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (3/3)</TD><TD>100% (1/1)</TD></TR><TR><TD CLASS="f"><A HREF="#21">getRequests (): DirtyRegion []</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (13/13)</TD><TD>100% (3/3)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#22">getTextViewer (): ITextViewer</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (3/3)</TD><TD>100% (1/1)</TD></TR><TR><TD CLASS="f"><A HREF="#23">handleInputDocumentChanged (IDocument, IDocument): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (7/7)</TD><TD>100% (3/3)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#24">install (ITextViewer): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (20/20)</TD><TD>100% (6/6)</TD></TR><TR><TD CLASS="f"><A HREF="#25">isInRewriteSession (): 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="#26">isInstalled (): boolean</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (3/3)</TD><TD>100% (1/1)</TD></TR><TR><TD CLASS="f"><A HREF="#27">setDelay (long): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (4/4)</TD><TD>100% (2/2)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#28">setDocument (IDocument): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (43/43)</TD><TD>100% (11/11)</TD></TR><TR><TD CLASS="f"><A HREF="#29">setDocumentPartitioning (String): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (4/4)</TD><TD>100% (2/2)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#2a">setInstalled (boolean): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (4/4)</TD><TD>100% (2/2)</TD></TR><TR><TD CLASS="f"><A HREF="#2b">uninstall (): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (18/18)</TD><TD>100% (6/6)</TD></TR><TR><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD></TR><TR CLASS="cis"><TD CLASS="f">class <A HREF="#2c">DirtyRegionProcessor$TextInputListener</A></TD><TD>100% (1/1)</TD><TD>100% (3/3)</TD><TD>100% (13/13)</TD><TD>100% (4/4)</TD></TR><TR><TD CLASS="f"><A HREF="#2c">DirtyRegionProcessor$TextInputListener (DirtyRegionProcessor): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (6/6)</TD><TD>100% (1/1)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#2e">inputDocumentAboutToBeChanged (IDocument, IDocument): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (1/1)</TD><TD>100% (1/1)</TD></TR><TR><TD CLASS="f"><A HREF="#2f">inputDocumentChanged (IDocument, IDocument): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (6/6)</TD><TD>100% (2/2)</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, 2008 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.sse.ui.internal.reconcile;</TD></TR><TR><TD CLASS="l">14</TD><TD> </TD></TR><TR><TD CLASS="l">15</TD><TD>import java.util.ArrayList;</TD></TR><TR><TD CLASS="l">16</TD><TD>import java.util.Collections;</TD></TR><TR><TD CLASS="l">17</TD><TD>import java.util.HashMap;</TD></TR><TR><TD CLASS="l">18</TD><TD>import java.util.Iterator;</TD></TR><TR><TD CLASS="l">19</TD><TD>import java.util.List;</TD></TR><TR><TD CLASS="l">20</TD><TD>import java.util.Map;</TD></TR><TR><TD CLASS="l">21</TD><TD> </TD></TR><TR><TD CLASS="l">22</TD><TD>import org.eclipse.core.runtime.IProgressMonitor;</TD></TR><TR><TD CLASS="l">23</TD><TD>import org.eclipse.core.runtime.IStatus;</TD></TR><TR><TD CLASS="l">24</TD><TD>import org.eclipse.core.runtime.OperationCanceledException;</TD></TR><TR><TD CLASS="l">25</TD><TD>import org.eclipse.core.runtime.Platform;</TD></TR><TR><TD CLASS="l">26</TD><TD>import org.eclipse.core.runtime.Status;</TD></TR><TR><TD CLASS="l">27</TD><TD>import org.eclipse.core.runtime.jobs.Job;</TD></TR><TR><TD CLASS="l">28</TD><TD>import org.eclipse.jface.text.BadLocationException;</TD></TR><TR><TD CLASS="l">29</TD><TD>import org.eclipse.jface.text.DocumentEvent;</TD></TR><TR><TD CLASS="l">30</TD><TD>import org.eclipse.jface.text.DocumentRewriteSessionEvent;</TD></TR><TR><TD CLASS="l">31</TD><TD>import org.eclipse.jface.text.IDocument;</TD></TR><TR><TD CLASS="l">32</TD><TD>import org.eclipse.jface.text.IDocumentExtension3;</TD></TR><TR><TD CLASS="l">33</TD><TD>import org.eclipse.jface.text.IDocumentExtension4;</TD></TR><TR><TD CLASS="l">34</TD><TD>import org.eclipse.jface.text.IDocumentListener;</TD></TR><TR><TD CLASS="l">35</TD><TD>import org.eclipse.jface.text.IDocumentRewriteSessionListener;</TD></TR><TR><TD CLASS="l">36</TD><TD>import org.eclipse.jface.text.ITextInputListener;</TD></TR><TR><TD CLASS="l">37</TD><TD>import org.eclipse.jface.text.ITextViewer;</TD></TR><TR><TD CLASS="l">38</TD><TD>import org.eclipse.jface.text.ITypedRegion;</TD></TR><TR><TD CLASS="l">39</TD><TD>import org.eclipse.jface.text.TextUtilities;</TD></TR><TR><TD CLASS="l">40</TD><TD>import org.eclipse.jface.text.reconciler.DirtyRegion;</TD></TR><TR><TD CLASS="l">41</TD><TD>import org.eclipse.jface.text.reconciler.IReconciler;</TD></TR><TR><TD CLASS="l">42</TD><TD>import org.eclipse.jface.text.reconciler.IReconcilerExtension;</TD></TR><TR><TD CLASS="l">43</TD><TD>import org.eclipse.jface.text.reconciler.IReconcilingStrategy;</TD></TR><TR><TD CLASS="l">44</TD><TD>import org.eclipse.ui.PlatformUI;</TD></TR><TR><TD CLASS="l">45</TD><TD>import org.eclipse.wst.sse.ui.internal.Logger;</TD></TR><TR><TD CLASS="l">46</TD><TD>import org.eclipse.wst.sse.ui.internal.SSEUIMessages;</TD></TR><TR><TD CLASS="l">47</TD><TD> </TD></TR><TR><TD CLASS="l">48</TD><TD>/**</TD></TR><TR><TD CLASS="l">49</TD><TD> * This Job holds a queue of updates from the editor (DirtyRegions) to</TD></TR><TR><TD CLASS="l">50</TD><TD> * process. When a new request comes in, the current run is canceled, the new</TD></TR><TR><TD CLASS="l">51</TD><TD> * request is added to the queue, then the job is re-scheduled.</TD></TR><TR><TD CLASS="l"><A NAME="0">52</A></TD><TD> * </TD></TR><TR><TD CLASS="l">53</TD><TD> * @author pavery</TD></TR><TR><TD CLASS="l">54</TD><TD> */</TD></TR><TR CLASS="c"><TD CLASS="l">55</TD><TD>public class DirtyRegionProcessor extends Job implements IReconciler, IReconcilerExtension, IConfigurableReconciler {</TD></TR><TR CLASS="c"><TD CLASS="l">56</TD><TD>        class DocumentListener implements IDocumentListener {</TD></TR><TR><TD CLASS="l">57</TD><TD>                public void documentAboutToBeChanged(DocumentEvent event) {</TD></TR><TR><TD CLASS="l"><A NAME="1">58</A></TD><TD>                        /*</TD></TR><TR><TD CLASS="l">59</TD><TD>                         * if in rewrite session and already going to reprocess entire</TD></TR><TR><TD CLASS="l">60</TD><TD>                         * document after rewrite session, do nothing</TD></TR><TR><TD CLASS="l">61</TD><TD>                         */</TD></TR><TR CLASS="z"><TD CLASS="l">62</TD><TD>                        if (isInRewriteSession() &amp;&amp; fReprocessAfterRewrite)</TD></TR><TR CLASS="z"><TD CLASS="l">63</TD><TD>                                return;</TD></TR><TR><TD CLASS="l">64</TD><TD>                        // save partition type (to see if it changes in documentChanged())</TD></TR><TR CLASS="z"><TD CLASS="l">65</TD><TD>                        fLastPartitions = getPartitionRegions(event.getOffset(), event.getLength());</TD></TR><TR CLASS="z"><TD CLASS="l">66</TD><TD>                }</TD></TR><TR><TD CLASS="l">67</TD><TD> </TD></TR><TR><TD CLASS="l">68</TD><TD>                public void documentChanged(DocumentEvent event) {</TD></TR><TR><TD CLASS="l"><A NAME="2">69</A></TD><TD>                        /*</TD></TR><TR><TD CLASS="l">70</TD><TD>                         * if in rewrite session and already going to reprocess entire</TD></TR><TR><TD CLASS="l">71</TD><TD>                         * document after rewrite session, do nothing</TD></TR><TR><TD CLASS="l">72</TD><TD>                         */</TD></TR><TR CLASS="z"><TD CLASS="l">73</TD><TD>                        if (isInRewriteSession() &amp;&amp; fReprocessAfterRewrite)</TD></TR><TR CLASS="z"><TD CLASS="l">74</TD><TD>                                return;</TD></TR><TR><TD CLASS="l">75</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">76</TD><TD>                        if (partitionsChanged(event)) {</TD></TR><TR><TD CLASS="l">77</TD><TD>                                // pa_TODO</TD></TR><TR><TD CLASS="l">78</TD><TD>                                // this is a simple way to ensure old</TD></TR><TR><TD CLASS="l">79</TD><TD>                                // annotations are removed when partition changes</TD></TR><TR><TD CLASS="l">80</TD><TD> </TD></TR><TR><TD CLASS="l">81</TD><TD>                                // it might be a performance hit though</TD></TR><TR CLASS="z"><TD CLASS="l">82</TD><TD>                                setEntireDocumentDirty(getDocument());</TD></TR><TR><TD CLASS="l">83</TD><TD>                        }</TD></TR><TR><TD CLASS="l">84</TD><TD>                        else {</TD></TR><TR><TD CLASS="l">85</TD><TD>                                /*</TD></TR><TR><TD CLASS="l">86</TD><TD>                                 * Note that creating DirtyRegions *now* means that the wrong</TD></TR><TR><TD CLASS="l">87</TD><TD>                                 * text may be included</TD></TR><TR><TD CLASS="l">88</TD><TD>                                 */</TD></TR><TR CLASS="z"><TD CLASS="l">89</TD><TD>                                DirtyRegion dr = null;</TD></TR><TR CLASS="z"><TD CLASS="l">90</TD><TD>                                if (event.getLength() == 0) {</TD></TR><TR><TD CLASS="l">91</TD><TD>                                        /*</TD></TR><TR><TD CLASS="l">92</TD><TD>                                         * It's an insert-- we use text length though so that the</TD></TR><TR><TD CLASS="l">93</TD><TD>                                         * new region gets validated...</TD></TR><TR><TD CLASS="l">94</TD><TD>                                         */</TD></TR><TR CLASS="z"><TD CLASS="l">95</TD><TD>                                        dr = createDirtyRegion(event.getOffset(), 0, DirtyRegion.INSERT);</TD></TR><TR><TD CLASS="l">96</TD><TD>                                }</TD></TR><TR><TD CLASS="l">97</TD><TD>                                else {</TD></TR><TR CLASS="z"><TD CLASS="l">98</TD><TD>                                        if (&#34;&#34;.equals(event.getText())) { //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">99</TD><TD>                                                // it's a delete</TD></TR><TR CLASS="z"><TD CLASS="l">100</TD><TD>                                                dr = createDirtyRegion(event.getOffset(), event.getLength(), DirtyRegion.REMOVE);</TD></TR><TR><TD CLASS="l">101</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">102</TD><TD>                                        else {</TD></TR><TR><TD CLASS="l">103</TD><TD>                                                // it's a replace</TD></TR><TR CLASS="z"><TD CLASS="l">104</TD><TD>                                                dr = createDirtyRegion(event.getOffset(), event.getLength(), DirtyRegion.INSERT);</TD></TR><TR><TD CLASS="l">105</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">106</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">107</TD><TD>                                if (isInRewriteSession()) {</TD></TR><TR><TD CLASS="l">108</TD><TD>                                        /*</TD></TR><TR><TD CLASS="l">109</TD><TD>                                         * while in rewrite session, found a dirty region, so flag</TD></TR><TR><TD CLASS="l">110</TD><TD>                                         * that entire document needs to be reprocesed after</TD></TR><TR><TD CLASS="l">111</TD><TD>                                         * rewrite session</TD></TR><TR><TD CLASS="l">112</TD><TD>                                         */</TD></TR><TR CLASS="z"><TD CLASS="l">113</TD><TD>                                        if (!fReprocessAfterRewrite &amp;&amp; (dr != null)) {</TD></TR><TR CLASS="z"><TD CLASS="l">114</TD><TD>                                                fReprocessAfterRewrite = true;</TD></TR><TR><TD CLASS="l">115</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">116</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">117</TD><TD>                                else {</TD></TR><TR CLASS="z"><TD CLASS="l">118</TD><TD>                                        processDirtyRegion(dr);</TD></TR><TR><TD CLASS="l">119</TD><TD>                                }</TD></TR><TR><TD CLASS="l">120</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">121</TD><TD>                }</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>                 * Checks previous partitions from the span of the event w/ the new</TD></TR><TR><TD CLASS="l">125</TD><TD>                 * partitions from the span of the event. If partitions changed,</TD></TR><TR><TD CLASS="l">126</TD><TD>                 * return true, else return false</TD></TR><TR><TD CLASS="l">127</TD><TD>                 * </TD></TR><TR><TD CLASS="l"><A NAME="3">128</A></TD><TD>                 * @param event</TD></TR><TR><TD CLASS="l">129</TD><TD>                 * @return</TD></TR><TR><TD CLASS="l">130</TD><TD>                 */</TD></TR><TR><TD CLASS="l">131</TD><TD>                private boolean partitionsChanged(DocumentEvent event) {</TD></TR><TR CLASS="z"><TD CLASS="l">132</TD><TD>                        boolean changed = false;</TD></TR><TR CLASS="z"><TD CLASS="l">133</TD><TD>                        int length = event.getLength();</TD></TR><TR><TD CLASS="l">134</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">135</TD><TD>                        if (event.getLength() == 0 &amp;&amp; event.getText().length() &gt; 0) {</TD></TR><TR><TD CLASS="l">136</TD><TD>                                // it's an insert, we want partitions of the new text</TD></TR><TR CLASS="z"><TD CLASS="l">137</TD><TD>                                length = event.getText().length();</TD></TR><TR><TD CLASS="l">138</TD><TD>                        }</TD></TR><TR><TD CLASS="l">139</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">140</TD><TD>                        ITypedRegion[] newPartitions = getPartitionRegions(event.getOffset(), length);</TD></TR><TR CLASS="z"><TD CLASS="l">141</TD><TD>                        if (fLastPartitions != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">142</TD><TD>                                if (fLastPartitions.length != newPartitions.length) {</TD></TR><TR CLASS="z"><TD CLASS="l">143</TD><TD>                                        changed = true;</TD></TR><TR><TD CLASS="l">144</TD><TD>                                }</TD></TR><TR><TD CLASS="l">145</TD><TD>                                else {</TD></TR><TR CLASS="z"><TD CLASS="l">146</TD><TD>                                        for (int i = 0; i &lt; fLastPartitions.length; i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">147</TD><TD>                                                if (!fLastPartitions[i].getType().equals(newPartitions[i].getType())) {</TD></TR><TR CLASS="z"><TD CLASS="l">148</TD><TD>                                                        changed = true;</TD></TR><TR CLASS="z"><TD CLASS="l">149</TD><TD>                                                        break;</TD></TR><TR><TD CLASS="l">150</TD><TD>                                                }</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 CLASS="z"><TD CLASS="l">154</TD><TD>                        return changed;</TD></TR><TR><TD CLASS="l">155</TD><TD>                }</TD></TR><TR><TD CLASS="l">156</TD><TD> </TD></TR><TR><TD CLASS="l">157</TD><TD> </TD></TR><TR><TD CLASS="l">158</TD><TD>        }</TD></TR><TR><TD CLASS="l">159</TD><TD> </TD></TR><TR><TD CLASS="l">160</TD><TD>        /**</TD></TR><TR><TD CLASS="l">161</TD><TD>         * Reconciles the entire document when the document in the viewer is</TD></TR><TR><TD CLASS="l">162</TD><TD>         * changed. This happens when the document is initially opened, as well as</TD></TR><TR><TD CLASS="l">163</TD><TD>         * after a save-as.</TD></TR><TR><TD CLASS="l"><A NAME="2c">164</A></TD><TD>         * </TD></TR><TR><TD CLASS="l">165</TD><TD>         * Also see processPostModelEvent(...) for similar behavior when document</TD></TR><TR><TD CLASS="l">166</TD><TD>         * for the model is changed.</TD></TR><TR><TD CLASS="l"><A NAME="2e">167</A></TD><TD>         */</TD></TR><TR CLASS="c"><TD CLASS="l">168</TD><TD>        class TextInputListener implements ITextInputListener {</TD></TR><TR><TD CLASS="l">169</TD><TD>                public void inputDocumentAboutToBeChanged(IDocument oldInput, IDocument newInput) {</TD></TR><TR><TD CLASS="l">170</TD><TD>                        // do nothing</TD></TR><TR CLASS="c"><TD CLASS="l"><A NAME="2f">171</A></TD><TD>                }</TD></TR><TR><TD CLASS="l">172</TD><TD> </TD></TR><TR><TD CLASS="l">173</TD><TD>                public void inputDocumentChanged(IDocument oldInput, IDocument newInput) {</TD></TR><TR CLASS="c"><TD CLASS="l"><A NAME="5">174</A></TD><TD>                        handleInputDocumentChanged(oldInput, newInput);</TD></TR><TR CLASS="c"><TD CLASS="l">175</TD><TD>                }</TD></TR><TR><TD CLASS="l">176</TD><TD>        }</TD></TR><TR><TD CLASS="l">177</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l"><A NAME="6">178</A></TD><TD>        class DocumentRewriteSessionListener implements IDocumentRewriteSessionListener {</TD></TR><TR CLASS="c"><TD CLASS="l">179</TD><TD>                long time0 = 0;</TD></TR><TR><TD CLASS="l">180</TD><TD> </TD></TR><TR><TD CLASS="l">181</TD><TD>                public void documentRewriteSessionChanged(DocumentRewriteSessionEvent event) {</TD></TR><TR CLASS="z"><TD CLASS="l">182</TD><TD>                        boolean oldValue = fInRewriteSession;</TD></TR><TR CLASS="z"><TD CLASS="l">183</TD><TD>                        fInRewriteSession = event != null &amp;&amp; event.getChangeType().equals(DocumentRewriteSessionEvent.SESSION_START);</TD></TR><TR><TD CLASS="l">184</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">185</TD><TD>                        if (event.getChangeType().equals(DocumentRewriteSessionEvent.SESSION_START)) {</TD></TR><TR CLASS="z"><TD CLASS="l">186</TD><TD>                                if (DEBUG) {</TD></TR><TR CLASS="z"><TD CLASS="l">187</TD><TD>                                        time0 = System.currentTimeMillis();</TD></TR><TR><TD CLASS="l">188</TD><TD>                                }</TD></TR><TR><TD CLASS="l">189</TD><TD>                                // bug 235446 - source validation annotations lost after rewrite session</TD></TR><TR CLASS="z"><TD CLASS="l">190</TD><TD>                                if (!getDirtyRegionQueue().isEmpty()) {</TD></TR><TR CLASS="z"><TD CLASS="l">191</TD><TD>                                        flushDirtyRegionQueue();</TD></TR><TR CLASS="z"><TD CLASS="l">192</TD><TD>                                        fReprocessAfterRewrite = true;        </TD></TR><TR><TD CLASS="l">193</TD><TD>                                } else {</TD></TR><TR CLASS="z"><TD CLASS="l">194</TD><TD>                                        fReprocessAfterRewrite = false;</TD></TR><TR><TD CLASS="l">195</TD><TD>                                }</TD></TR><TR><TD CLASS="l">196</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">197</TD><TD>                        else if (event.getChangeType().equals(DocumentRewriteSessionEvent.SESSION_STOP)) {</TD></TR><TR CLASS="z"><TD CLASS="l">198</TD><TD>                                if (fInRewriteSession ^ oldValue &amp;&amp; fDocument != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">199</TD><TD>                                        if (DEBUG) {</TD></TR><TR CLASS="z"><TD CLASS="l">200</TD><TD>                                                Logger.log(Logger.INFO, &#34;Rewrite session lasted &#34; + (System.currentTimeMillis() - time0) + &#34;ms&#34;);</TD></TR><TR CLASS="z"><TD CLASS="l">201</TD><TD>                                                time0 = System.currentTimeMillis();</TD></TR><TR><TD CLASS="l">202</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">203</TD><TD>                                        if (fReprocessAfterRewrite) {</TD></TR><TR CLASS="z"><TD CLASS="l">204</TD><TD>                                                DirtyRegion entireDocument = createDirtyRegion(0, fDocument.getLength(), DirtyRegion.INSERT);</TD></TR><TR CLASS="z"><TD CLASS="l">205</TD><TD>                                                processDirtyRegion(entireDocument);</TD></TR><TR><TD CLASS="l">206</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">207</TD><TD>                                        if (DEBUG) {</TD></TR><TR CLASS="z"><TD CLASS="l">208</TD><TD>                                                Logger.log(Logger.INFO, &#34;Full document reprocess took &#34; + (System.currentTimeMillis() - time0) + &#34;ms&#34;);</TD></TR><TR><TD CLASS="l">209</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">210</TD><TD>                                        fReprocessAfterRewrite = false;</TD></TR><TR><TD CLASS="l">211</TD><TD>                                }</TD></TR><TR><TD CLASS="l">212</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">213</TD><TD>                }</TD></TR><TR><TD CLASS="l">214</TD><TD>        }</TD></TR><TR><TD CLASS="l">215</TD><TD> </TD></TR><TR><TD CLASS="l">216</TD><TD>        /** debug flag */</TD></TR><TR><TD CLASS="l"><A NAME="8">217</A></TD><TD>        protected static final boolean DEBUG;</TD></TR><TR><TD CLASS="l">218</TD><TD>        private static final long UPDATE_DELAY = 750;</TD></TR><TR><TD CLASS="l">219</TD><TD> </TD></TR><TR><TD CLASS="l">220</TD><TD>        static {</TD></TR><TR CLASS="c"><TD CLASS="l">221</TD><TD>                String value = Platform.getDebugOption(&#34;org.eclipse.wst.sse.ui/debug/reconcilerjob&#34;); //$NON-NLS-1$</TD></TR><TR CLASS="p"><TD CLASS="l" TITLE="57% line coverage (8 out of 14 instructions)">222</TD><TD TITLE="57% line coverage (8 out of 14 instructions)">                DEBUG = value != null &amp;&amp; value.equalsIgnoreCase(&#34;true&#34;); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">223</TD><TD>        }</TD></TR><TR><TD CLASS="l">224</TD><TD> </TD></TR><TR><TD CLASS="l">225</TD><TD>        private long fDelay;</TD></TR><TR><TD CLASS="l">226</TD><TD> </TD></TR><TR><TD CLASS="l">227</TD><TD> </TD></TR><TR><TD CLASS="l">228</TD><TD>        /** local queue of dirty regions (created here) to be reconciled */</TD></TR><TR CLASS="c"><TD CLASS="l">229</TD><TD>        private List fDirtyRegionQueue = Collections.synchronizedList(new ArrayList());</TD></TR><TR><TD CLASS="l">230</TD><TD> </TD></TR><TR><TD CLASS="l">231</TD><TD>        /** document that this reconciler works on */</TD></TR><TR CLASS="c"><TD CLASS="l">232</TD><TD>        private IDocument fDocument = null;</TD></TR><TR><TD CLASS="l">233</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">234</TD><TD>        private IDocumentListener fDocumentListener = new DocumentListener();</TD></TR><TR CLASS="c"><TD CLASS="l">235</TD><TD>        private IDocumentRewriteSessionListener fDocumentRewriteSessionListener = new DocumentRewriteSessionListener();</TD></TR><TR><TD CLASS="l">236</TD><TD> </TD></TR><TR><TD CLASS="l">237</TD><TD>        /**</TD></TR><TR><TD CLASS="l">238</TD><TD>         * set true after first install to prevent duplicate work done in the</TD></TR><TR><TD CLASS="l">239</TD><TD>         * install method (since install gets called multiple times)</TD></TR><TR><TD CLASS="l">240</TD><TD>         */</TD></TR><TR CLASS="c"><TD CLASS="l">241</TD><TD>        private boolean fIsInstalled = false;</TD></TR><TR><TD CLASS="l">242</TD><TD> </TD></TR><TR><TD CLASS="l">243</TD><TD>        /**</TD></TR><TR><TD CLASS="l">244</TD><TD>         * so we can tell if a partition changed after the last edit</TD></TR><TR><TD CLASS="l">245</TD><TD>         */</TD></TR><TR><TD CLASS="l">246</TD><TD>        ITypedRegion[] fLastPartitions;</TD></TR><TR><TD CLASS="l">247</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">248</TD><TD>        List fNonIncrementalStrategiesAlreadyProcessed = new ArrayList(1);</TD></TR><TR><TD CLASS="l">249</TD><TD> </TD></TR><TR><TD CLASS="l">250</TD><TD>        /**</TD></TR><TR><TD CLASS="l">251</TD><TD>         * The partitioning this reconciler uses.</TD></TR><TR><TD CLASS="l">252</TD><TD>         */</TD></TR><TR><TD CLASS="l">253</TD><TD>        private String fPartitioning;</TD></TR><TR><TD CLASS="l">254</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">255</TD><TD>        Map fReconcilingStrategies = null;</TD></TR><TR><TD CLASS="l">256</TD><TD> </TD></TR><TR><TD CLASS="l">257</TD><TD>        /** for initial reconcile when document is opened */</TD></TR><TR CLASS="c"><TD CLASS="l">258</TD><TD>        private TextInputListener fTextInputListener = null;</TD></TR><TR><TD CLASS="l">259</TD><TD>        /** the text viewer */</TD></TR><TR><TD CLASS="l">260</TD><TD>        private ITextViewer fViewer;</TD></TR><TR CLASS="c"><TD CLASS="l">261</TD><TD>        boolean fInRewriteSession = false;</TD></TR><TR><TD CLASS="l">262</TD><TD>        /**</TD></TR><TR><TD CLASS="l">263</TD><TD>         * true if entire document needs to be reprocessed after rewrite session</TD></TR><TR><TD CLASS="l">264</TD><TD>         */</TD></TR><TR CLASS="c"><TD CLASS="l">265</TD><TD>        boolean fReprocessAfterRewrite = false;</TD></TR><TR><TD CLASS="l">266</TD><TD> </TD></TR><TR><TD CLASS="l">267</TD><TD>        /**</TD></TR><TR><TD CLASS="l"><A NAME="18">268</A></TD><TD>         * Creates a new StructuredRegionProcessor</TD></TR><TR><TD CLASS="l">269</TD><TD>         */</TD></TR><TR><TD CLASS="l">270</TD><TD>        public DirtyRegionProcessor() {</TD></TR><TR><TD CLASS="l">271</TD><TD>                // init job stuff</TD></TR><TR CLASS="c"><TD CLASS="l">272</TD><TD>                super(SSEUIMessages.proc_dirty_regions_0); //$NON-NLS-1$</TD></TR><TR CLASS="c"><TD CLASS="l">273</TD><TD>                setPriority(Job.LONG);</TD></TR><TR CLASS="c"><TD CLASS="l">274</TD><TD>                setSystem(true);</TD></TR><TR><TD CLASS="l">275</TD><TD> </TD></TR><TR><TD CLASS="l">276</TD><TD>                // init reconciler stuff</TD></TR><TR CLASS="c"><TD CLASS="l">277</TD><TD>                setDelay(UPDATE_DELAY);</TD></TR><TR CLASS="c"><TD CLASS="l">278</TD><TD>                fReconcilingStrategies = new HashMap();</TD></TR><TR CLASS="c"><TD CLASS="l">279</TD><TD>        }</TD></TR><TR><TD CLASS="l">280</TD><TD> </TD></TR><TR><TD CLASS="l">281</TD><TD>        /**</TD></TR><TR><TD CLASS="l">282</TD><TD>         * Adds the given resource to the set of resources that need refreshing.</TD></TR><TR><TD CLASS="l">283</TD><TD>         * Synchronized in order to protect the collection during add.</TD></TR><TR><TD CLASS="l">284</TD><TD>         * </TD></TR><TR><TD CLASS="l"><A NAME="11">285</A></TD><TD>         * @param resource</TD></TR><TR><TD CLASS="l">286</TD><TD>         */</TD></TR><TR><TD CLASS="l">287</TD><TD>        private synchronized void addRequest(DirtyRegion newDirtyRegion) {</TD></TR><TR><TD CLASS="l">288</TD><TD>                // NOTE: This method is called a lot so make sure it's fast</TD></TR><TR CLASS="c"><TD CLASS="l">289</TD><TD>                List dirtyRegionQueue = getDirtyRegionQueue();</TD></TR><TR CLASS="c"><TD CLASS="l">290</TD><TD>                for (Iterator it = dirtyRegionQueue.iterator(); it.hasNext();) {</TD></TR><TR><TD CLASS="l">291</TD><TD>                        // go through list of existing dirty regions and check if any</TD></TR><TR><TD CLASS="l">292</TD><TD>                        // dirty regions need to be discarded</TD></TR><TR CLASS="z"><TD CLASS="l">293</TD><TD>                        DirtyRegion currentExisting = (DirtyRegion) it.next();</TD></TR><TR CLASS="z"><TD CLASS="l">294</TD><TD>                        DirtyRegion outer = getOuterRegion(currentExisting, newDirtyRegion);</TD></TR><TR><TD CLASS="l">295</TD><TD>                        // if we already have a request which contains the new request,</TD></TR><TR><TD CLASS="l">296</TD><TD>                        // discard the new request</TD></TR><TR CLASS="z"><TD CLASS="l">297</TD><TD>                        if (outer == currentExisting)</TD></TR><TR CLASS="z"><TD CLASS="l">298</TD><TD>                                return;</TD></TR><TR><TD CLASS="l">299</TD><TD>                        // if new request contains any existing requests,</TD></TR><TR><TD CLASS="l">300</TD><TD>                        // remove those</TD></TR><TR CLASS="z"><TD CLASS="l">301</TD><TD>                        if (outer == newDirtyRegion)</TD></TR><TR CLASS="z"><TD CLASS="l">302</TD><TD>                                it.remove();</TD></TR><TR><TD CLASS="l">303</TD><TD>                }</TD></TR><TR CLASS="c"><TD CLASS="l">304</TD><TD>                dirtyRegionQueue.add(newDirtyRegion);</TD></TR><TR CLASS="c"><TD CLASS="l">305</TD><TD>        }</TD></TR><TR><TD CLASS="l">306</TD><TD> </TD></TR><TR><TD CLASS="l">307</TD><TD>        /**</TD></TR><TR><TD CLASS="l"><A NAME="19">308</A></TD><TD>         * Notifies subclasses that processing of multiple dirty regions has begun</TD></TR><TR><TD CLASS="l">309</TD><TD>         */</TD></TR><TR><TD CLASS="l">310</TD><TD>        protected void beginProcessing() {</TD></TR><TR><TD CLASS="l">311</TD><TD>                // do nothing by default</TD></TR><TR CLASS="c"><TD CLASS="l">312</TD><TD>        }</TD></TR><TR><TD CLASS="l">313</TD><TD> </TD></TR><TR><TD CLASS="l">314</TD><TD>        /**</TD></TR><TR><TD CLASS="l"><A NAME="1a">315</A></TD><TD>         * @param dirtyRegion</TD></TR><TR><TD CLASS="l">316</TD><TD>         * @return</TD></TR><TR><TD CLASS="l">317</TD><TD>         */</TD></TR><TR><TD CLASS="l">318</TD><TD>        protected ITypedRegion[] computePartitioning(DirtyRegion dirtyRegion) {</TD></TR><TR CLASS="c"><TD CLASS="l">319</TD><TD>                int drOffset = dirtyRegion.getOffset();</TD></TR><TR CLASS="c"><TD CLASS="l">320</TD><TD>                int drLength = dirtyRegion.getLength();</TD></TR><TR><TD CLASS="l">321</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l"><A NAME="10">322</A></TD><TD>                return computePartitioning(drOffset, drLength);</TD></TR><TR><TD CLASS="l">323</TD><TD>        }</TD></TR><TR><TD CLASS="l">324</TD><TD> </TD></TR><TR><TD CLASS="l">325</TD><TD>        protected ITypedRegion[] computePartitioning(int drOffset, int drLength) {</TD></TR><TR CLASS="c"><TD CLASS="l">326</TD><TD>                IDocument doc = getDocument();</TD></TR><TR CLASS="c"><TD CLASS="l">327</TD><TD>                int docLength = doc.getLength();</TD></TR><TR><TD CLASS="l">328</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">329</TD><TD>                ITypedRegion[] tr = new ITypedRegion[0];</TD></TR><TR><TD CLASS="l">330</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">331</TD><TD>                if (drOffset &gt; docLength) {</TD></TR><TR CLASS="z"><TD CLASS="l">332</TD><TD>                        drOffset = docLength;</TD></TR><TR CLASS="z"><TD CLASS="l">333</TD><TD>                        drLength = 0;</TD></TR><TR><TD CLASS="l">334</TD><TD>                }</TD></TR><TR CLASS="c"><TD CLASS="l">335</TD><TD>                else if (drOffset + drLength &gt; docLength) {</TD></TR><TR CLASS="z"><TD CLASS="l">336</TD><TD>                        drLength = docLength - drOffset;</TD></TR><TR><TD CLASS="l">337</TD><TD>                }</TD></TR><TR><TD CLASS="l">338</TD><TD> </TD></TR><TR><TD CLASS="l">339</TD><TD>                try {</TD></TR><TR><TD CLASS="l">340</TD><TD>                        // dirty region may span multiple partitions</TD></TR><TR CLASS="c"><TD CLASS="l">341</TD><TD>                        tr = TextUtilities.computePartitioning(doc, getDocumentPartitioning(), drOffset, drLength, true);</TD></TR><TR><TD CLASS="l">342</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">343</TD><TD>                catch (BadLocationException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">344</TD><TD>                        String info = &#34;dr: [&#34; + drOffset + &#34;:&#34; + drLength + &#34;] doc: [&#34; + docLength + &#34;] &#34;; //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$</TD></TR><TR CLASS="z"><TD CLASS="l">345</TD><TD>                        Logger.logException(info, e);</TD></TR><TR CLASS="z"><TD CLASS="l">346</TD><TD>                        tr = new ITypedRegion[0];</TD></TR><TR><TD CLASS="l">347</TD><TD>                }</TD></TR><TR CLASS="c"><TD CLASS="l">348</TD><TD>                return tr;</TD></TR><TR><TD CLASS="l">349</TD><TD>        }</TD></TR><TR><TD CLASS="l">350</TD><TD> </TD></TR><TR><TD CLASS="l">351</TD><TD>        /**</TD></TR><TR><TD CLASS="l">352</TD><TD>         * Used to determine if one dirty region contains the other and if so,</TD></TR><TR><TD CLASS="l">353</TD><TD>         * which is the one that contains it.</TD></TR><TR><TD CLASS="l">354</TD><TD>         * </TD></TR><TR><TD CLASS="l">355</TD><TD>         * @param root</TD></TR><TR><TD CLASS="l">356</TD><TD>         * @param possible</TD></TR><TR><TD CLASS="l"><A NAME="9">357</A></TD><TD>         * @return the outer dirty region if it contains the other dirty region,</TD></TR><TR><TD CLASS="l">358</TD><TD>         *         null otherwise</TD></TR><TR><TD CLASS="l">359</TD><TD>         */</TD></TR><TR><TD CLASS="l">360</TD><TD>        protected DirtyRegion getOuterRegion(DirtyRegion root, DirtyRegion possible) {</TD></TR><TR CLASS="z"><TD CLASS="l">361</TD><TD>                DirtyRegion outer = null;</TD></TR><TR CLASS="z"><TD CLASS="l">362</TD><TD>                if (isContained(root, possible))</TD></TR><TR CLASS="z"><TD CLASS="l">363</TD><TD>                        outer = root;</TD></TR><TR CLASS="z"><TD CLASS="l">364</TD><TD>                else if (isContained(possible, root))</TD></TR><TR CLASS="z"><TD CLASS="l">365</TD><TD>                        outer = possible;</TD></TR><TR CLASS="z"><TD CLASS="l">366</TD><TD>                return outer;</TD></TR><TR><TD CLASS="l">367</TD><TD>        }</TD></TR><TR><TD CLASS="l">368</TD><TD> </TD></TR><TR><TD CLASS="l">369</TD><TD>        /**</TD></TR><TR><TD CLASS="l">370</TD><TD>         * Used to determine of a &#34;possible&#34; dirty region can be discarded in</TD></TR><TR><TD CLASS="l">371</TD><TD>         * favor of using just the &#34;root&#34; dirty region.</TD></TR><TR><TD CLASS="l">372</TD><TD>         * </TD></TR><TR><TD CLASS="l"><A NAME="c">373</A></TD><TD>         * @return if the root dirty region contains possible, return true,</TD></TR><TR><TD CLASS="l">374</TD><TD>         *         otherwise return false</TD></TR><TR><TD CLASS="l">375</TD><TD>         */</TD></TR><TR><TD CLASS="l">376</TD><TD>        private boolean isContained(DirtyRegion root, DirtyRegion possible) {</TD></TR><TR CLASS="z"><TD CLASS="l">377</TD><TD>                int rootStart = root.getOffset();</TD></TR><TR CLASS="z"><TD CLASS="l">378</TD><TD>                int rootEnd = rootStart + root.getLength();</TD></TR><TR CLASS="z"><TD CLASS="l">379</TD><TD>                int possStart = possible.getOffset();</TD></TR><TR CLASS="z"><TD CLASS="l">380</TD><TD>                int possEnd = possStart + possible.getLength();</TD></TR><TR CLASS="z"><TD CLASS="l">381</TD><TD>                if (rootStart &lt;= possStart &amp;&amp; rootEnd &gt;= possEnd)</TD></TR><TR CLASS="z"><TD CLASS="l">382</TD><TD>                        return true;</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="13">383</A></TD><TD>                return false;</TD></TR><TR><TD CLASS="l">384</TD><TD>        }</TD></TR><TR><TD CLASS="l">385</TD><TD> </TD></TR><TR><TD CLASS="l">386</TD><TD>        protected DirtyRegion createDirtyRegion(int offset, int length, String type) {</TD></TR><TR CLASS="c"><TD CLASS="l">387</TD><TD>                DirtyRegion durty = null;</TD></TR><TR CLASS="c"><TD CLASS="l">388</TD><TD>                IDocument doc = getDocument();</TD></TR><TR><TD CLASS="l">389</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">390</TD><TD>                if (doc != null) {</TD></TR><TR><TD CLASS="l">391</TD><TD>                        // safety for BLE</TD></TR><TR CLASS="c"><TD CLASS="l">392</TD><TD>                        int docLen = doc.getLength();</TD></TR><TR CLASS="c"><TD CLASS="l">393</TD><TD>                        if (offset &gt; docLen) {</TD></TR><TR CLASS="z"><TD CLASS="l">394</TD><TD>                                offset = docLen;</TD></TR><TR CLASS="z"><TD CLASS="l">395</TD><TD>                                length = 0;</TD></TR><TR><TD CLASS="l">396</TD><TD>                        }</TD></TR><TR CLASS="c"><TD CLASS="l">397</TD><TD>                        else if (offset + length &gt;= docLen)</TD></TR><TR CLASS="c"><TD CLASS="l">398</TD><TD>                                length = docLen - offset;</TD></TR><TR><TD CLASS="l">399</TD><TD>                        try {</TD></TR><TR CLASS="c"><TD CLASS="l">400</TD><TD>                                durty = new DirtyRegion(offset, length, type, doc.get(offset, length));</TD></TR><TR><TD CLASS="l">401</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">402</TD><TD>                        catch (BadLocationException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">403</TD><TD>                                String info = &#34;dr: [&#34; + offset + &#34;:&#34; + length + &#34;] doc: [&#34; + docLen + &#34;] &#34;; //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$</TD></TR><TR CLASS="z"><TD CLASS="l">404</TD><TD>                                Logger.logException(info, e);</TD></TR><TR><TD CLASS="l">405</TD><TD>                        }</TD></TR><TR><TD CLASS="l">406</TD><TD>                }</TD></TR><TR CLASS="c"><TD CLASS="l"><A NAME="1b">407</A></TD><TD>                return durty;</TD></TR><TR><TD CLASS="l">408</TD><TD>        }</TD></TR><TR><TD CLASS="l">409</TD><TD> </TD></TR><TR><TD CLASS="l">410</TD><TD>        protected DirtyRegion createDirtyRegion(ITypedRegion tr, String type) {</TD></TR><TR CLASS="c"><TD CLASS="l"><A NAME="1d">411</A></TD><TD>                return createDirtyRegion(tr.getOffset(), tr.getLength(), type);</TD></TR><TR><TD CLASS="l">412</TD><TD>        }</TD></TR><TR><TD CLASS="l">413</TD><TD> </TD></TR><TR><TD CLASS="l">414</TD><TD>        protected void flushDirtyRegionQueue() {</TD></TR><TR CLASS="c"><TD CLASS="l">415</TD><TD>                fDirtyRegionQueue.clear();</TD></TR><TR CLASS="c"><TD CLASS="l">416</TD><TD>        }</TD></TR><TR><TD CLASS="l">417</TD><TD> </TD></TR><TR><TD CLASS="l">418</TD><TD>        /**</TD></TR><TR><TD CLASS="l">419</TD><TD>         * Notifies subclasses that processing of multiple dirty regions has</TD></TR><TR><TD CLASS="l"><A NAME="1c">420</A></TD><TD>         * ended, for now</TD></TR><TR><TD CLASS="l">421</TD><TD>         */</TD></TR><TR><TD CLASS="l">422</TD><TD>        protected void endProcessing() {</TD></TR><TR><TD CLASS="l">423</TD><TD>                // do nothing by default</TD></TR><TR CLASS="c"><TD CLASS="l">424</TD><TD>        }</TD></TR><TR><TD CLASS="l">425</TD><TD> </TD></TR><TR><TD CLASS="l">426</TD><TD>        /**</TD></TR><TR><TD CLASS="l">427</TD><TD>         * Delay between processing of DirtyRegions.</TD></TR><TR><TD CLASS="l"><A NAME="1e">428</A></TD><TD>         * </TD></TR><TR><TD CLASS="l">429</TD><TD>         * @return</TD></TR><TR><TD CLASS="l">430</TD><TD>         */</TD></TR><TR><TD CLASS="l">431</TD><TD>        long getDelay() {</TD></TR><TR CLASS="c"><TD CLASS="l"><A NAME="1f">432</A></TD><TD>                return fDelay;</TD></TR><TR><TD CLASS="l">433</TD><TD>        }</TD></TR><TR><TD CLASS="l">434</TD><TD> </TD></TR><TR><TD CLASS="l">435</TD><TD>        List getDirtyRegionQueue() {</TD></TR><TR CLASS="c"><TD CLASS="l">436</TD><TD>                return fDirtyRegionQueue;</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>        /**</TD></TR><TR><TD CLASS="l">440</TD><TD>         * The IDocument on which this reconciler operates</TD></TR><TR><TD CLASS="l"><A NAME="20">441</A></TD><TD>         * </TD></TR><TR><TD CLASS="l">442</TD><TD>         * @return</TD></TR><TR><TD CLASS="l">443</TD><TD>         */</TD></TR><TR><TD CLASS="l">444</TD><TD>        protected IDocument getDocument() {</TD></TR><TR CLASS="c"><TD CLASS="l"><A NAME="15">445</A></TD><TD>                return fDocument;</TD></TR><TR><TD CLASS="l">446</TD><TD>        }</TD></TR><TR><TD CLASS="l">447</TD><TD> </TD></TR><TR><TD CLASS="l">448</TD><TD>        public String getDocumentPartitioning() {</TD></TR><TR CLASS="c"><TD CLASS="l">449</TD><TD>                if (fPartitioning == null)</TD></TR><TR CLASS="z"><TD CLASS="l">450</TD><TD>                        return IDocumentExtension3.DEFAULT_PARTITIONING;</TD></TR><TR CLASS="c"><TD CLASS="l">451</TD><TD>                return fPartitioning;</TD></TR><TR><TD CLASS="l"><A NAME="b">452</A></TD><TD>        }</TD></TR><TR><TD CLASS="l">453</TD><TD> </TD></TR><TR><TD CLASS="l">454</TD><TD>        protected String[] getPartitions(int drOffset, int drLength) {</TD></TR><TR><TD CLASS="l">455</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">456</TD><TD>                ITypedRegion[] regions = new ITypedRegion[0];</TD></TR><TR CLASS="z"><TD CLASS="l">457</TD><TD>                int docLength = getDocument().getLength();</TD></TR><TR><TD CLASS="l">458</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">459</TD><TD>                if (drOffset &gt; docLength) {</TD></TR><TR CLASS="z"><TD CLASS="l">460</TD><TD>                        drOffset = docLength;</TD></TR><TR CLASS="z"><TD CLASS="l">461</TD><TD>                        drLength = 0;</TD></TR><TR><TD CLASS="l">462</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">463</TD><TD>                else if (drOffset + drLength &gt; docLength) {</TD></TR><TR CLASS="z"><TD CLASS="l">464</TD><TD>                        drLength = docLength - drOffset;</TD></TR><TR><TD CLASS="l">465</TD><TD>                }</TD></TR><TR><TD CLASS="l">466</TD><TD> </TD></TR><TR><TD CLASS="l">467</TD><TD>                try {</TD></TR><TR CLASS="z"><TD CLASS="l">468</TD><TD>                        regions = TextUtilities.computePartitioning(getDocument(), getDocumentPartitioning(), drOffset, drLength, true);</TD></TR><TR><TD CLASS="l">469</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">470</TD><TD>                catch (BadLocationException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">471</TD><TD>                        Logger.logException(e);</TD></TR><TR CLASS="z"><TD CLASS="l">472</TD><TD>                        regions = new ITypedRegion[0];</TD></TR><TR><TD CLASS="l">473</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">474</TD><TD>                String[] partitions = new String[regions.length];</TD></TR><TR CLASS="z"><TD CLASS="l">475</TD><TD>                for (int i = 0; i &lt; regions.length; i++)</TD></TR><TR CLASS="z"><TD CLASS="l">476</TD><TD>                        partitions[i] = regions[i].getType();</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="a">477</A></TD><TD>                return partitions;</TD></TR><TR><TD CLASS="l">478</TD><TD>        }</TD></TR><TR><TD CLASS="l">479</TD><TD> </TD></TR><TR><TD CLASS="l">480</TD><TD>        ITypedRegion[] getPartitionRegions(int drOffset, int drLength) {</TD></TR><TR CLASS="z"><TD CLASS="l">481</TD><TD>                ITypedRegion[] regions = new ITypedRegion[0];</TD></TR><TR CLASS="z"><TD CLASS="l">482</TD><TD>                int docLength = getDocument().getLength();</TD></TR><TR><TD CLASS="l">483</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">484</TD><TD>                if (drOffset &gt; docLength) {</TD></TR><TR CLASS="z"><TD CLASS="l">485</TD><TD>                        drOffset = docLength;</TD></TR><TR CLASS="z"><TD CLASS="l">486</TD><TD>                        drLength = 0;</TD></TR><TR><TD CLASS="l">487</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">488</TD><TD>                else if (drOffset + drLength &gt; docLength) {</TD></TR><TR CLASS="z"><TD CLASS="l">489</TD><TD>                        drLength = docLength - drOffset;</TD></TR><TR><TD CLASS="l">490</TD><TD>                }</TD></TR><TR><TD CLASS="l">491</TD><TD> </TD></TR><TR><TD CLASS="l">492</TD><TD>                try {</TD></TR><TR CLASS="z"><TD CLASS="l">493</TD><TD>                        regions = TextUtilities.computePartitioning(getDocument(), getDocumentPartitioning(), drOffset, drLength, true);</TD></TR><TR><TD CLASS="l">494</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">495</TD><TD>                catch (BadLocationException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">496</TD><TD>                        Logger.logException(e);</TD></TR><TR CLASS="z"><TD CLASS="l">497</TD><TD>                        regions = new ITypedRegion[0];</TD></TR><TR><TD CLASS="l">498</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">499</TD><TD>                return regions;</TD></TR><TR><TD CLASS="l">500</TD><TD>        }</TD></TR><TR><TD CLASS="l">501</TD><TD>                </TD></TR><TR><TD CLASS="l">502</TD><TD>                </TD></TR><TR><TD CLASS="l">503</TD><TD>        /**</TD></TR><TR><TD CLASS="l">504</TD><TD>         * Returns the reconciling strategy registered with the reconciler for the</TD></TR><TR><TD CLASS="l">505</TD><TD>         * specified partition type.</TD></TR><TR><TD CLASS="l">506</TD><TD>         * </TD></TR><TR><TD CLASS="l">507</TD><TD>         * @param partitionType</TD></TR><TR><TD CLASS="l">508</TD><TD>         *            the partition type for which to determine the reconciling</TD></TR><TR><TD CLASS="l">509</TD><TD>         *            strategy</TD></TR><TR><TD CLASS="l">510</TD><TD>         * </TD></TR><TR><TD CLASS="l">511</TD><TD>         * @return the reconciling strategy registered for the given partition</TD></TR><TR><TD CLASS="l">512</TD><TD>         *         type, or &lt;code&gt;null&lt;/code&gt; if there is no such strategy</TD></TR><TR><TD CLASS="l"><A NAME="16">513</A></TD><TD>         * </TD></TR><TR><TD CLASS="l">514</TD><TD>         * @see org.eclipse.jface.text.reconciler.IReconciler#getReconcilingStrategy(java.lang.String)</TD></TR><TR><TD CLASS="l">515</TD><TD>         */</TD></TR><TR><TD CLASS="l">516</TD><TD>        public IReconcilingStrategy getReconcilingStrategy(String partitionType) {</TD></TR><TR CLASS="c"><TD CLASS="l">517</TD><TD>                if (partitionType == null)</TD></TR><TR CLASS="z"><TD CLASS="l">518</TD><TD>                        return null;</TD></TR><TR CLASS="c"><TD CLASS="l">519</TD><TD>                return (IReconcilingStrategy) fReconcilingStrategies.get(partitionType);</TD></TR><TR><TD CLASS="l">520</TD><TD>        }</TD></TR><TR><TD CLASS="l">521</TD><TD> </TD></TR><TR><TD CLASS="l">522</TD><TD>        /**</TD></TR><TR><TD CLASS="l">523</TD><TD>         * This method also synchronized because it accesses the fRequests queue</TD></TR><TR><TD CLASS="l"><A NAME="21">524</A></TD><TD>         * </TD></TR><TR><TD CLASS="l">525</TD><TD>         * @return an array of the currently requested Nodes to refresh</TD></TR><TR><TD CLASS="l">526</TD><TD>         */</TD></TR><TR><TD CLASS="l">527</TD><TD>        private synchronized DirtyRegion[] getRequests() {</TD></TR><TR CLASS="c"><TD CLASS="l">528</TD><TD>                DirtyRegion[] toRefresh = (DirtyRegion[]) fDirtyRegionQueue.toArray(new DirtyRegion[fDirtyRegionQueue.size()]);</TD></TR><TR CLASS="c"><TD CLASS="l">529</TD><TD>                flushDirtyRegionQueue();</TD></TR><TR CLASS="c"><TD CLASS="l">530</TD><TD>                return toRefresh;</TD></TR><TR><TD CLASS="l">531</TD><TD>        }</TD></TR><TR><TD CLASS="l">532</TD><TD> </TD></TR><TR><TD CLASS="l">533</TD><TD>        /**</TD></TR><TR><TD CLASS="l">534</TD><TD>         * Returns the text viewer this reconciler is installed on.</TD></TR><TR><TD CLASS="l"><A NAME="22">535</A></TD><TD>         * </TD></TR><TR><TD CLASS="l">536</TD><TD>         * @return the text viewer this reconciler is installed on</TD></TR><TR><TD CLASS="l">537</TD><TD>         */</TD></TR><TR><TD CLASS="l">538</TD><TD>        protected ITextViewer getTextViewer() {</TD></TR><TR CLASS="c"><TD CLASS="l">539</TD><TD>                return fViewer;</TD></TR><TR><TD CLASS="l">540</TD><TD>        }</TD></TR><TR><TD CLASS="l">541</TD><TD> </TD></TR><TR><TD CLASS="l">542</TD><TD>        /**</TD></TR><TR><TD CLASS="l">543</TD><TD>         * </TD></TR><TR><TD CLASS="l">544</TD><TD>         * @param oldInput</TD></TR><TR><TD CLASS="l"><A NAME="23">545</A></TD><TD>         * @param newInput</TD></TR><TR><TD CLASS="l">546</TD><TD>         */</TD></TR><TR><TD CLASS="l">547</TD><TD>        void handleInputDocumentChanged(IDocument oldInput, IDocument newInput) {</TD></TR><TR><TD CLASS="l">548</TD><TD>                // don't bother if reconciler not installed</TD></TR><TR CLASS="c"><TD CLASS="l">549</TD><TD>                if (isInstalled()) {</TD></TR><TR CLASS="c"><TD CLASS="l">550</TD><TD>                        setDocument(newInput);</TD></TR><TR><TD CLASS="l">551</TD><TD>                }</TD></TR><TR CLASS="c"><TD CLASS="l">552</TD><TD>        }</TD></TR><TR><TD CLASS="l">553</TD><TD> </TD></TR><TR><TD CLASS="l">554</TD><TD>        /**</TD></TR><TR><TD CLASS="l">555</TD><TD>         * @see org.eclipse.jface.text.reconciler.IReconciler#install(ITextViewer)</TD></TR><TR><TD CLASS="l"><A NAME="24">556</A></TD><TD>         */</TD></TR><TR><TD CLASS="l">557</TD><TD>        public void install(ITextViewer textViewer) {</TD></TR><TR><TD CLASS="l">558</TD><TD>                // we might be called multiple times with the same viewe.r,</TD></TR><TR><TD CLASS="l">559</TD><TD>                // maybe after being uninstalled as well, so track separately</TD></TR><TR CLASS="c"><TD CLASS="l">560</TD><TD>                if (!isInstalled()) {</TD></TR><TR CLASS="c"><TD CLASS="l">561</TD><TD>                        fViewer = textViewer;</TD></TR><TR CLASS="c"><TD CLASS="l">562</TD><TD>                        fTextInputListener = new TextInputListener();</TD></TR><TR CLASS="c"><TD CLASS="l">563</TD><TD>                        textViewer.addTextInputListener(fTextInputListener);</TD></TR><TR CLASS="c"><TD CLASS="l">564</TD><TD>                        setInstalled(true);</TD></TR><TR><TD CLASS="l">565</TD><TD>                }</TD></TR><TR CLASS="c"><TD CLASS="l">566</TD><TD>        }</TD></TR><TR><TD CLASS="l">567</TD><TD> </TD></TR><TR><TD CLASS="l">568</TD><TD>        /**</TD></TR><TR><TD CLASS="l">569</TD><TD>         * The viewer has been set on this Reconciler.</TD></TR><TR><TD CLASS="l">570</TD><TD>         * </TD></TR><TR><TD CLASS="l"><A NAME="26">571</A></TD><TD>         * @return true if the viewer has been set on this Reconciler, false</TD></TR><TR><TD CLASS="l">572</TD><TD>         *         otherwise.</TD></TR><TR><TD CLASS="l">573</TD><TD>         */</TD></TR><TR><TD CLASS="l">574</TD><TD>        public boolean isInstalled() {</TD></TR><TR CLASS="c"><TD CLASS="l"><A NAME="25">575</A></TD><TD>                return fIsInstalled;</TD></TR><TR><TD CLASS="l">576</TD><TD>        }</TD></TR><TR><TD CLASS="l">577</TD><TD> </TD></TR><TR><TD CLASS="l">578</TD><TD>        boolean isInRewriteSession() {</TD></TR><TR CLASS="c"><TD CLASS="l">579</TD><TD>                return fInRewriteSession;</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>        /**</TD></TR><TR><TD CLASS="l">583</TD><TD>         * Subclasses should implement for specific handling of dirty regions. The</TD></TR><TR><TD CLASS="l">584</TD><TD>         * method is invoked for each dirty region in the Job's queue.</TD></TR><TR><TD CLASS="l"><A NAME="17">585</A></TD><TD>         * </TD></TR><TR><TD CLASS="l">586</TD><TD>         * @param dirtyRegion</TD></TR><TR><TD CLASS="l">587</TD><TD>         */</TD></TR><TR><TD CLASS="l">588</TD><TD>        protected void process(DirtyRegion dirtyRegion) {</TD></TR><TR CLASS="c"><TD CLASS="l">589</TD><TD>                if (isInRewriteSession()) {</TD></TR><TR CLASS="z"><TD CLASS="l">590</TD><TD>                        return;</TD></TR><TR><TD CLASS="l">591</TD><TD>                }</TD></TR><TR><TD CLASS="l">592</TD><TD>                /*</TD></TR><TR><TD CLASS="l">593</TD><TD>                 * Break the dirty region into a sequence of partitions and find the</TD></TR><TR><TD CLASS="l">594</TD><TD>                 * corresponding strategy to reconcile those partitions. If a strategy</TD></TR><TR><TD CLASS="l">595</TD><TD>                 * implements INonIncrementalReconcilingStrategy, only call it once</TD></TR><TR><TD CLASS="l">596</TD><TD>                 * regardless of the number and types of partitions.</TD></TR><TR><TD CLASS="l">597</TD><TD>                 */</TD></TR><TR CLASS="c"><TD CLASS="l">598</TD><TD>                ITypedRegion[] partitions = computePartitioning(dirtyRegion);</TD></TR><TR CLASS="c"><TD CLASS="l">599</TD><TD>                for (int i = 0; i &lt; partitions.length; i++) {</TD></TR><TR CLASS="c"><TD CLASS="l">600</TD><TD>                        IReconcilingStrategy strategy = getReconcilingStrategy(partitions[i].getType());</TD></TR><TR CLASS="c"><TD CLASS="l">601</TD><TD>                        if (strategy != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">602</TD><TD>                                strategy.reconcile(partitions[i]);</TD></TR><TR><TD CLASS="l">603</TD><TD>                        }</TD></TR><TR><TD CLASS="l">604</TD><TD>                }</TD></TR><TR CLASS="c"><TD CLASS="l">605</TD><TD>        }</TD></TR><TR><TD CLASS="l">606</TD><TD> </TD></TR><TR><TD CLASS="l">607</TD><TD>        /**</TD></TR><TR><TD CLASS="l">608</TD><TD>         * Invoke dirty region processing.</TD></TR><TR><TD CLASS="l"><A NAME="f">609</A></TD><TD>         * </TD></TR><TR><TD CLASS="l">610</TD><TD>         * @param node</TD></TR><TR><TD CLASS="l">611</TD><TD>         */</TD></TR><TR><TD CLASS="l">612</TD><TD>        public final void processDirtyRegion(DirtyRegion dr) {</TD></TR><TR CLASS="c"><TD CLASS="l">613</TD><TD>                if (dr == null || !isInstalled())</TD></TR><TR CLASS="z"><TD CLASS="l">614</TD><TD>                        return;</TD></TR><TR><TD CLASS="l">615</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">616</TD><TD>                cancel();</TD></TR><TR CLASS="c"><TD CLASS="l">617</TD><TD>                addRequest(dr);</TD></TR><TR CLASS="c"><TD CLASS="l">618</TD><TD>                schedule(getDelay());</TD></TR><TR><TD CLASS="l">619</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">620</TD><TD>                if (DEBUG) {</TD></TR><TR CLASS="z"><TD CLASS="l">621</TD><TD>                        System.out.println(&#34;added request for: [&#34; + dr.getText() + &#34;]&#34;); //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR CLASS="z"><TD CLASS="l">622</TD><TD>                        System.out.println(&#34;queue size is now: &#34; + getDirtyRegionQueue().size()); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l"><A NAME="14">623</A></TD><TD>                }</TD></TR><TR CLASS="c"><TD CLASS="l">624</TD><TD>        }</TD></TR><TR><TD CLASS="l">625</TD><TD> </TD></TR><TR><TD CLASS="l">626</TD><TD>        protected IStatus run(IProgressMonitor monitor) {</TD></TR><TR CLASS="c"><TD CLASS="l">627</TD><TD>                IStatus status = Status.OK_STATUS;</TD></TR><TR CLASS="c"><TD CLASS="l">628</TD><TD>                if (!PlatformUI.isWorkbenchRunning())</TD></TR><TR CLASS="z"><TD CLASS="l">629</TD><TD>                        return status;</TD></TR><TR><TD CLASS="l">630</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">631</TD><TD>                Thread.currentThread().setPriority(Thread.MIN_PRIORITY);</TD></TR><TR><TD CLASS="l">632</TD><TD>                try {</TD></TR><TR CLASS="c"><TD CLASS="l">633</TD><TD>                        beginProcessing();</TD></TR><TR><TD CLASS="l">634</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">635</TD><TD>                        DirtyRegion[] toRefresh = getRequests();</TD></TR><TR CLASS="p"><TD CLASS="l" TITLE="96% line coverage (24 out of 25 instructions)">636</TD><TD TITLE="96% line coverage (24 out of 25 instructions)">                        for (int i = 0; i &lt; toRefresh.length &amp;&amp; fDocument != null; i++) {</TD></TR><TR CLASS="c"><TD CLASS="l">637</TD><TD>                                if (monitor.isCanceled())</TD></TR><TR CLASS="z"><TD CLASS="l">638</TD><TD>                                        throw new OperationCanceledException();</TD></TR><TR CLASS="c"><TD CLASS="l">639</TD><TD>                                process(toRefresh[i]);</TD></TR><TR><TD CLASS="l">640</TD><TD>                        }</TD></TR><TR><TD CLASS="l">641</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">642</TD><TD>                catch (Exception e) {</TD></TR><TR><TD CLASS="l">643</TD><TD>                        // https://bugs.eclipse.org/bugs/show_bug.cgi?id=103676</TD></TR><TR><TD CLASS="l">644</TD><TD>                        // stop errors from popping up a dialog</TD></TR><TR><TD CLASS="l">645</TD><TD>                        // from the job manager</TD></TR><TR><TD CLASS="l">646</TD><TD> </TD></TR><TR><TD CLASS="l">647</TD><TD>                        // https://bugs.eclipse.org/bugs/show_bug.cgi?id=106052</TD></TR><TR><TD CLASS="l">648</TD><TD>                        // don't log OperationCanceledException</TD></TR><TR CLASS="z"><TD CLASS="l">649</TD><TD>                        if (!(e instanceof OperationCanceledException))</TD></TR><TR CLASS="z"><TD CLASS="l">650</TD><TD>                                Logger.logException(&#34;problem with reconciling&#34;, e); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">651</TD><TD>                }</TD></TR><TR CLASS="p"><TD CLASS="l" TITLE="75% line coverage (6 out of 8 instructions)">652</TD><TD TITLE="75% line coverage (6 out of 8 instructions)">                finally {</TD></TR><TR CLASS="c"><TD CLASS="l">653</TD><TD>                        endProcessing();</TD></TR><TR><TD CLASS="l">654</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">655</TD><TD>                        monitor.done();</TD></TR><TR CLASS="p"><TD CLASS="l" TITLE="78% line coverage (7 out of 9 instructions)">656</TD><TD TITLE="78% line coverage (7 out of 9 instructions)">                }</TD></TR><TR CLASS="c"><TD CLASS="l"><A NAME="27">657</A></TD><TD>                return status;</TD></TR><TR><TD CLASS="l">658</TD><TD>        }</TD></TR><TR><TD CLASS="l">659</TD><TD> </TD></TR><TR><TD CLASS="l">660</TD><TD>        public void setDelay(long delay) {</TD></TR><TR CLASS="c"><TD CLASS="l"><A NAME="28">661</A></TD><TD>                fDelay = delay;</TD></TR><TR CLASS="c"><TD CLASS="l">662</TD><TD>        }</TD></TR><TR><TD CLASS="l">663</TD><TD> </TD></TR><TR><TD CLASS="l">664</TD><TD>        public void setDocument(IDocument doc) {</TD></TR><TR CLASS="c"><TD CLASS="l">665</TD><TD>                if (fDocument != null) {</TD></TR><TR><TD CLASS="l">666</TD><TD>                        // unhook old document listener</TD></TR><TR CLASS="c"><TD CLASS="l">667</TD><TD>                        fDocument.removeDocumentListener(fDocumentListener);</TD></TR><TR CLASS="c"><TD CLASS="l">668</TD><TD>                        if (fDocument instanceof IDocumentExtension4) {</TD></TR><TR CLASS="c"><TD CLASS="l">669</TD><TD>                                ((IDocumentExtension4) fDocument).removeDocumentRewriteSessionListener(fDocumentRewriteSessionListener);</TD></TR><TR><TD CLASS="l">670</TD><TD>                        }</TD></TR><TR><TD CLASS="l">671</TD><TD>                }</TD></TR><TR><TD CLASS="l">672</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">673</TD><TD>                fDocument = doc;</TD></TR><TR><TD CLASS="l">674</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">675</TD><TD>                if (fDocument != null) {</TD></TR><TR CLASS="c"><TD CLASS="l">676</TD><TD>                        if (fDocument instanceof IDocumentExtension4) {</TD></TR><TR CLASS="c"><TD CLASS="l">677</TD><TD>                                ((IDocumentExtension4) fDocument).addDocumentRewriteSessionListener(fDocumentRewriteSessionListener);</TD></TR><TR><TD CLASS="l">678</TD><TD>                        }</TD></TR><TR><TD CLASS="l">679</TD><TD>                        // hook up new document listener</TD></TR><TR CLASS="c"><TD CLASS="l">680</TD><TD>                        fDocument.addDocumentListener(fDocumentListener);</TD></TR><TR><TD CLASS="l">681</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">682</TD><TD>                        setEntireDocumentDirty(doc);</TD></TR><TR><TD CLASS="l">683</TD><TD>                }</TD></TR><TR CLASS="c"><TD CLASS="l">684</TD><TD>        }</TD></TR><TR><TD CLASS="l">685</TD><TD> </TD></TR><TR><TD CLASS="l">686</TD><TD>        /**</TD></TR><TR><TD CLASS="l">687</TD><TD>         * Sets the document partitioning for this reconciler.</TD></TR><TR><TD CLASS="l">688</TD><TD>         * </TD></TR><TR><TD CLASS="l"><A NAME="29">689</A></TD><TD>         * @param partitioning</TD></TR><TR><TD CLASS="l">690</TD><TD>         *            the document partitioning for this reconciler</TD></TR><TR><TD CLASS="l">691</TD><TD>         */</TD></TR><TR><TD CLASS="l">692</TD><TD>        public void setDocumentPartitioning(String partitioning) {</TD></TR><TR CLASS="c"><TD CLASS="l">693</TD><TD>                fPartitioning = partitioning;</TD></TR><TR CLASS="c"><TD CLASS="l">694</TD><TD>        }</TD></TR><TR><TD CLASS="l">695</TD><TD> </TD></TR><TR><TD CLASS="l">696</TD><TD>        /**</TD></TR><TR><TD CLASS="l">697</TD><TD>         * Basically means process the entire document.</TD></TR><TR><TD CLASS="l">698</TD><TD>         * </TD></TR><TR><TD CLASS="l">699</TD><TD>         * @param document</TD></TR><TR><TD CLASS="l">700</TD><TD>         */</TD></TR><TR><TD CLASS="l"><A NAME="e">701</A></TD><TD>        protected void setEntireDocumentDirty(IDocument document) {</TD></TR><TR><TD CLASS="l">702</TD><TD> </TD></TR><TR><TD CLASS="l">703</TD><TD>                // make the entire document dirty</TD></TR><TR><TD CLASS="l">704</TD><TD>                // this also happens on a &#34;save as&#34;</TD></TR><TR CLASS="c"><TD CLASS="l">705</TD><TD>                if (document != null &amp;&amp; isInstalled()) {</TD></TR><TR><TD CLASS="l">706</TD><TD> </TD></TR><TR><TD CLASS="l">707</TD><TD>                        // since we're marking the entire doc dirty</TD></TR><TR CLASS="c"><TD CLASS="l">708</TD><TD>                        flushDirtyRegionQueue();</TD></TR><TR><TD CLASS="l">709</TD><TD> </TD></TR><TR><TD CLASS="l">710</TD><TD>                        /**</TD></TR><TR><TD CLASS="l">711</TD><TD>                         * https://bugs.eclipse.org/bugs/show_bug.cgi?id=199053</TD></TR><TR><TD CLASS="l">712</TD><TD>                         * </TD></TR><TR><TD CLASS="l">713</TD><TD>                         * Process the strategies for the last known-good partitions to</TD></TR><TR><TD CLASS="l">714</TD><TD>                         * ensure all problem annotations are cleared if needed.</TD></TR><TR><TD CLASS="l">715</TD><TD>                         */</TD></TR><TR CLASS="p"><TD CLASS="l" TITLE="62% line coverage (5 out of 8 instructions)">716</TD><TD TITLE="62% line coverage (5 out of 8 instructions)">                        if (fLastPartitions != null &amp;&amp; document.getLength() == 0) {</TD></TR><TR CLASS="z"><TD CLASS="l">717</TD><TD>                                for (int i = 0; i &lt; fLastPartitions.length; i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">718</TD><TD>                                        IReconcilingStrategy strategy = getReconcilingStrategy(fLastPartitions[i].getType());</TD></TR><TR CLASS="z"><TD CLASS="l">719</TD><TD>                                        if (strategy != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">720</TD><TD>                                                strategy.reconcile(fLastPartitions[i]);</TD></TR><TR><TD CLASS="l">721</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">722</TD><TD>                                }</TD></TR><TR><TD CLASS="l">723</TD><TD>                        }</TD></TR><TR><TD CLASS="l">724</TD><TD>                        else {</TD></TR><TR CLASS="c"><TD CLASS="l">725</TD><TD>                                DirtyRegion entireDocument = createDirtyRegion(0, document.getLength(), DirtyRegion.INSERT);</TD></TR><TR CLASS="c"><TD CLASS="l">726</TD><TD>                                processDirtyRegion(entireDocument);</TD></TR><TR><TD CLASS="l">727</TD><TD>                        }</TD></TR><TR><TD CLASS="l">728</TD><TD>                }</TD></TR><TR CLASS="c"><TD CLASS="l">729</TD><TD>        }</TD></TR><TR><TD CLASS="l">730</TD><TD> </TD></TR><TR><TD CLASS="l">731</TD><TD>        /**</TD></TR><TR><TD CLASS="l"><A NAME="2a">732</A></TD><TD>         * @param isInstalled</TD></TR><TR><TD CLASS="l">733</TD><TD>         *            The isInstalled to set.</TD></TR><TR><TD CLASS="l">734</TD><TD>         */</TD></TR><TR><TD CLASS="l">735</TD><TD>        void setInstalled(boolean isInstalled) {</TD></TR><TR CLASS="c"><TD CLASS="l"><A NAME="d">736</A></TD><TD>                fIsInstalled = isInstalled;</TD></TR><TR CLASS="c"><TD CLASS="l">737</TD><TD>        }</TD></TR><TR><TD CLASS="l">738</TD><TD> </TD></TR><TR><TD CLASS="l">739</TD><TD>        public void setReconcilingStrategy(String partitionType, IReconcilingStrategy strategy) {</TD></TR><TR CLASS="z"><TD CLASS="l">740</TD><TD>                if (partitionType == null) {</TD></TR><TR CLASS="z"><TD CLASS="l">741</TD><TD>                        throw new IllegalArgumentException();</TD></TR><TR><TD CLASS="l">742</TD><TD>                }</TD></TR><TR><TD CLASS="l">743</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">744</TD><TD>                if (strategy == null) {</TD></TR><TR CLASS="z"><TD CLASS="l">745</TD><TD>                        fReconcilingStrategies.remove(partitionType);</TD></TR><TR><TD CLASS="l">746</TD><TD>                }</TD></TR><TR><TD CLASS="l">747</TD><TD>                else {</TD></TR><TR CLASS="z"><TD CLASS="l">748</TD><TD>                        fReconcilingStrategies.put(partitionType, strategy);</TD></TR><TR><TD CLASS="l">749</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">750</TD><TD>        }</TD></TR><TR><TD CLASS="l">751</TD><TD> </TD></TR><TR><TD CLASS="l"><A NAME="2b">752</A></TD><TD>        /**</TD></TR><TR><TD CLASS="l">753</TD><TD>         * @see org.eclipse.jface.text.reconciler.IReconciler#uninstall()</TD></TR><TR><TD CLASS="l">754</TD><TD>         */</TD></TR><TR><TD CLASS="l">755</TD><TD>        public void uninstall() {</TD></TR><TR CLASS="c"><TD CLASS="l">756</TD><TD>                if (isInstalled()) {</TD></TR><TR><TD CLASS="l">757</TD><TD>                        // removes widget listener</TD></TR><TR CLASS="c"><TD CLASS="l">758</TD><TD>                        getTextViewer().removeTextInputListener(fTextInputListener);</TD></TR><TR CLASS="c"><TD CLASS="l">759</TD><TD>                        setInstalled(false);</TD></TR><TR><TD CLASS="l">760</TD><TD>                }</TD></TR><TR CLASS="c"><TD CLASS="l">761</TD><TD>                fDirtyRegionQueue.clear();</TD></TR><TR CLASS="c"><TD CLASS="l">762</TD><TD>                setDocument(null);</TD></TR><TR CLASS="c"><TD CLASS="l">763</TD><TD>        }</TD></TR><TR><TD CLASS="l">764</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="ad.html">org.eclipse.wst.sse.ui.internal.reconcile</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>