blob: 2fa59fdbf8f6edf93fc3728227b883726eda2155 [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="7e.html">org.eclipse.wst.sse.ui.internal</A>]</TD></TR></TABLE><H2>COVERAGE SUMMARY FOR SOURCE FILE [<SPAN CLASS="in">StorageModelProvider.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>StorageModelProvider.java</TD><TD CLASS="h">0%   (0/3)</TD><TD CLASS="h">0%   (0/29)</TD><TD CLASS="h">0%   (0/1253)</TD><TD CLASS="h">0%   (0/313)</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">StorageModelProvider</A></TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/22)</TD><TD CLASS="h">0%   (0/994)</TD><TD CLASS="h">0%   (0/249)</TD></TR><TR><TD CLASS="f"><A HREF="#0">&lt;static initializer&gt;</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/13)</TD><TD CLASS="h">0%   (0/4)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#2">StorageModelProvider (): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/18)</TD><TD CLASS="h">0%   (0/5)</TD></TR><TR><TD CLASS="f"><A HREF="#3">calculateBaseLocation (IStorageEditorInput): String</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/56)</TD><TD CLASS="h">0%   (0/19)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#4">calculateID (IStorageEditorInput): String</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/67)</TD><TD CLASS="h">0%   (0/20)</TD></TR><TR><TD CLASS="f"><A HREF="#5">createAnnotationModel (Object): IAnnotationModel</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/92)</TD><TD CLASS="h">0%   (0/19)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#6">createDocument (Object): IDocument</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/171)</TD><TD CLASS="h">0%   (0/45)</TD></TR><TR><TD CLASS="f"><A HREF="#7">createElementInfo (Object): AbstractDocumentProvider$ElementInfo</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/55)</TD><TD CLASS="h">0%   (0/10)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#8">createModelInfo (IEditorInput): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/16)</TD><TD CLASS="h">0%   (0/5)</TD></TR><TR><TD CLASS="f"><A HREF="#9">createModelInfo (IEditorInput, IStructuredModel, boolean): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/114)</TD><TD CLASS="h">0%   (0/20)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#a">disposeElementInfo (Object, AbstractDocumentProvider$ElementInfo): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/58)</TD><TD CLASS="h">0%   (0/12)</TD></TR><TR><TD CLASS="f"><A HREF="#b">disposeModelInfo (StorageModelProvider$ModelInfo): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/71)</TD><TD CLASS="h">0%   (0/13)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#c">doResetDocument (Object, IProgressMonitor): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/11)</TD><TD CLASS="h">0%   (0/4)</TD></TR><TR><TD CLASS="f"><A HREF="#d">doSaveDocument (IProgressMonitor, Object, IDocument, boolean): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/23)</TD><TD CLASS="h">0%   (0/7)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#e">getInstance (): StorageModelProvider</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/8)</TD><TD CLASS="h">0%   (0/3)</TD></TR><TR><TD CLASS="f"><A HREF="#f">getModel (IEditorInput): IStructuredModel</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/13)</TD><TD CLASS="h">0%   (0/5)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#10">getModel (Object): IStructuredModel</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><TD CLASS="f"><A HREF="#11">getModelInfoFor (IEditorInput): StorageModelProvider$ModelInfo</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/8)</TD><TD CLASS="h">0%   (0/2)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#12">getModelInfoFor (IStructuredModel): StorageModelProvider$ModelInfo</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/34)</TD><TD CLASS="h">0%   (0/9)</TD></TR><TR><TD CLASS="f"><A HREF="#13">getPersistedEncoding (Object): String</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/70)</TD><TD CLASS="h">0%   (0/20)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#14">loadModel (IStorageEditorInput): IStructuredModel</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/5)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR><TD CLASS="f"><A HREF="#15">loadModel (IStorageEditorInput, boolean): IStructuredModel</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/76)</TD><TD CLASS="h">0%   (0/22)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#16">selfCreateModel (IEditorInput): IStructuredModel</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/5)</TD><TD CLASS="h">0%   (0/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="#17">StorageModelProvider$InternalElementStateListener</A></TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/6)</TD><TD CLASS="h">0%   (0/244)</TD><TD CLASS="h">0%   (0/59)</TD></TR><TR><TD CLASS="f"><A HREF="#17">StorageModelProvider$InternalElementStateListener (StorageModelProvider): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/6)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#19">elementContentAboutToBeReplaced (Object): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/18)</TD><TD CLASS="h">0%   (0/4)</TD></TR><TR><TD CLASS="f"><A HREF="#1a">elementContentReplaced (Object): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/156)</TD><TD CLASS="h">0%   (0/42)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#1b">elementDeleted (Object): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/18)</TD><TD CLASS="h">0%   (0/4)</TD></TR><TR><TD CLASS="f"><A HREF="#1c">elementDirtyStateChanged (Object, boolean): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/25)</TD><TD CLASS="h">0%   (0/4)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#1d">elementMoved (Object, Object): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/21)</TD><TD CLASS="h">0%   (0/4)</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="#1e">StorageModelProvider$ModelInfo</A></TD><TD CLASS="h">0%   (0/1)</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="#1e">StorageModelProvider$ModelInfo (StorageModelProvider, IStructuredModel, IEdit...</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></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.sse.ui.internal;</TD></TR><TR><TD CLASS="l">14</TD><TD> </TD></TR><TR><TD CLASS="l">15</TD><TD>import java.io.IOException;</TD></TR><TR><TD CLASS="l">16</TD><TD>import java.io.InputStream;</TD></TR><TR><TD CLASS="l">17</TD><TD>import java.io.Reader;</TD></TR><TR><TD CLASS="l">18</TD><TD>import java.util.HashMap;</TD></TR><TR><TD CLASS="l">19</TD><TD>import java.util.Map;</TD></TR><TR><TD CLASS="l">20</TD><TD> </TD></TR><TR><TD CLASS="l">21</TD><TD>import org.eclipse.core.resources.IEncodedStorage;</TD></TR><TR><TD CLASS="l">22</TD><TD>import org.eclipse.core.resources.IResource;</TD></TR><TR><TD CLASS="l">23</TD><TD>import org.eclipse.core.resources.IStorage;</TD></TR><TR><TD CLASS="l">24</TD><TD>import org.eclipse.core.runtime.CoreException;</TD></TR><TR><TD CLASS="l">25</TD><TD>import org.eclipse.core.runtime.IPath;</TD></TR><TR><TD CLASS="l">26</TD><TD>import org.eclipse.core.runtime.IProgressMonitor;</TD></TR><TR><TD CLASS="l">27</TD><TD>import org.eclipse.core.runtime.Platform;</TD></TR><TR><TD CLASS="l">28</TD><TD>import org.eclipse.core.runtime.QualifiedName;</TD></TR><TR><TD CLASS="l">29</TD><TD>import org.eclipse.core.runtime.content.IContentDescription;</TD></TR><TR><TD CLASS="l">30</TD><TD>import org.eclipse.jface.text.IDocument;</TD></TR><TR><TD CLASS="l">31</TD><TD>import org.eclipse.jface.text.source.AnnotationModel;</TD></TR><TR><TD CLASS="l">32</TD><TD>import org.eclipse.jface.text.source.IAnnotationModel;</TD></TR><TR><TD CLASS="l">33</TD><TD>import org.eclipse.osgi.util.NLS;</TD></TR><TR><TD CLASS="l">34</TD><TD>import org.eclipse.ui.IEditorInput;</TD></TR><TR><TD CLASS="l">35</TD><TD>import org.eclipse.ui.IStorageEditorInput;</TD></TR><TR><TD CLASS="l">36</TD><TD>import org.eclipse.ui.editors.text.FileDocumentProvider;</TD></TR><TR><TD CLASS="l">37</TD><TD>import org.eclipse.ui.editors.text.StorageDocumentProvider;</TD></TR><TR><TD CLASS="l">38</TD><TD>import org.eclipse.ui.texteditor.DocumentProviderRegistry;</TD></TR><TR><TD CLASS="l">39</TD><TD>import org.eclipse.ui.texteditor.IDocumentProvider;</TD></TR><TR><TD CLASS="l">40</TD><TD>import org.eclipse.ui.texteditor.IElementStateListener;</TD></TR><TR><TD CLASS="l">41</TD><TD>import org.eclipse.wst.sse.core.StructuredModelManager;</TD></TR><TR><TD CLASS="l">42</TD><TD>import org.eclipse.wst.sse.core.internal.encoding.CodedReaderCreator;</TD></TR><TR><TD CLASS="l">43</TD><TD>import org.eclipse.wst.sse.core.internal.provisional.IStructuredModel;</TD></TR><TR><TD CLASS="l">44</TD><TD>import org.eclipse.wst.sse.core.internal.provisional.text.IStructuredDocument;</TD></TR><TR><TD CLASS="l">45</TD><TD>import org.eclipse.wst.sse.core.internal.util.Utilities;</TD></TR><TR><TD CLASS="l">46</TD><TD>import org.eclipse.wst.sse.ui.internal.debug.BreakpointRulerAction;</TD></TR><TR><TD CLASS="l">47</TD><TD>import org.eclipse.wst.sse.ui.internal.editor.EditorModelUtil;</TD></TR><TR><TD CLASS="l">48</TD><TD>import org.eclipse.wst.sse.ui.internal.extension.BreakpointProviderBuilder;</TD></TR><TR><TD CLASS="l">49</TD><TD>import org.eclipse.wst.sse.ui.internal.provisional.extensions.breakpoint.IExtendedStorageEditorInput;</TD></TR><TR><TD CLASS="l">50</TD><TD> </TD></TR><TR><TD CLASS="l">51</TD><TD>/**</TD></TR><TR><TD CLASS="l"><A NAME="17">52</A></TD><TD> * A StorageDocumentProvider that is IStructuredModel aware</TD></TR><TR><TD CLASS="l">53</TD><TD> */</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="19">54</A></TD><TD>public class StorageModelProvider extends StorageDocumentProvider implements IModelProvider {</TD></TR><TR><TD CLASS="l">55</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">56</TD><TD>        private class InternalElementStateListener implements IElementStateListener {</TD></TR><TR><TD CLASS="l">57</TD><TD>                public void elementContentAboutToBeReplaced(Object element) {</TD></TR><TR CLASS="z"><TD CLASS="l">58</TD><TD>                        if (debugElementStatelistener) {</TD></TR><TR CLASS="z"><TD CLASS="l">59</TD><TD>                                System.out.println(&#34;StorageModelProvider: elementContentAboutToBeReplaced: &#34; + ((IEditorInput) element).getName()); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">60</TD><TD>                        }</TD></TR><TR><TD CLASS="l">61</TD><TD>                        // we just forward the event</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="1a">62</A></TD><TD>                        StorageModelProvider.this.fireElementContentAboutToBeReplaced(element);</TD></TR><TR CLASS="z"><TD CLASS="l">63</TD><TD>                }</TD></TR><TR><TD CLASS="l">64</TD><TD> </TD></TR><TR><TD CLASS="l">65</TD><TD>                public void elementContentReplaced(Object element) {</TD></TR><TR CLASS="z"><TD CLASS="l">66</TD><TD>                        if (debugElementStatelistener) {</TD></TR><TR CLASS="z"><TD CLASS="l">67</TD><TD>                                System.out.println(&#34;StorageModelProvider: elementContentReplaced: &#34; + ((IEditorInput) element).getName()); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">68</TD><TD>                        }</TD></TR><TR><TD CLASS="l">69</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">70</TD><TD>                        StorageInfo info = (StorageInfo) getElementInfo(element);</TD></TR><TR><TD CLASS="l">71</TD><TD>                        </TD></TR><TR CLASS="z"><TD CLASS="l">72</TD><TD>                        if (info == null)</TD></TR><TR CLASS="z"><TD CLASS="l">73</TD><TD>                                return;</TD></TR><TR><TD CLASS="l">74</TD><TD> </TD></TR><TR><TD CLASS="l">75</TD><TD>                        /**</TD></TR><TR><TD CLASS="l">76</TD><TD>                         * Force a reload of the markers into annotations since their</TD></TR><TR><TD CLASS="l">77</TD><TD>                         * previous Positions have been deleted. Disconnecting and</TD></TR><TR><TD CLASS="l">78</TD><TD>                         * reconnecting forces a call to the private catchupWithMarkers</TD></TR><TR><TD CLASS="l">79</TD><TD>                         * method.</TD></TR><TR><TD CLASS="l">80</TD><TD>                         */</TD></TR><TR CLASS="z"><TD CLASS="l">81</TD><TD>                        if (info.fModel != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">82</TD><TD>                                info.fModel.disconnect(info.fDocument);</TD></TR><TR><TD CLASS="l">83</TD><TD>                        }</TD></TR><TR><TD CLASS="l">84</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">85</TD><TD>                        Reader reader = null;</TD></TR><TR CLASS="z"><TD CLASS="l">86</TD><TD>                        IStructuredDocument innerdocument = null;</TD></TR><TR><TD CLASS="l">87</TD><TD>                        try {</TD></TR><TR><TD CLASS="l">88</TD><TD>                                // update document from input's contents</TD></TR><TR CLASS="z"><TD CLASS="l">89</TD><TD>                                CodedReaderCreator codedReaderCreator = new CodedReaderCreator(calculateID((IStorageEditorInput) element), Utilities.getMarkSupportedStream(((IStorageEditorInput) element).getStorage().getContents()));</TD></TR><TR CLASS="z"><TD CLASS="l">90</TD><TD>                                reader = codedReaderCreator.getCodedReader();</TD></TR><TR><TD CLASS="l">91</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">92</TD><TD>                                innerdocument = (IStructuredDocument) info.fDocument;</TD></TR><TR><TD CLASS="l">93</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">94</TD><TD>                                int originalLengthToReplace = innerdocument.getLength();</TD></TR><TR><TD CLASS="l">95</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">96</TD><TD>                                StringBuffer stringBuffer = new StringBuffer();</TD></TR><TR CLASS="z"><TD CLASS="l">97</TD><TD>                                int bufferSize = 2048;</TD></TR><TR CLASS="z"><TD CLASS="l">98</TD><TD>                                char[] buffer = new char[bufferSize];</TD></TR><TR CLASS="z"><TD CLASS="l">99</TD><TD>                                int nRead = 0;</TD></TR><TR CLASS="z"><TD CLASS="l">100</TD><TD>                                boolean eof = false;</TD></TR><TR CLASS="z"><TD CLASS="l">101</TD><TD>                                while (!eof) {</TD></TR><TR CLASS="z"><TD CLASS="l">102</TD><TD>                                        nRead = reader.read(buffer, 0, bufferSize);</TD></TR><TR CLASS="z"><TD CLASS="l">103</TD><TD>                                        if (nRead == -1) {</TD></TR><TR CLASS="z"><TD CLASS="l">104</TD><TD>                                                eof = true;</TD></TR><TR><TD CLASS="l">105</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">106</TD><TD>                                        else {</TD></TR><TR CLASS="z"><TD CLASS="l">107</TD><TD>                                                stringBuffer.append(buffer, 0, nRead);</TD></TR><TR><TD CLASS="l">108</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">109</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">110</TD><TD>                                innerdocument.replaceText(this, 0, originalLengthToReplace, stringBuffer.toString(), true);</TD></TR><TR><TD CLASS="l">111</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">112</TD><TD>                        catch (CoreException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">113</TD><TD>                                Logger.logException(e);</TD></TR><TR><TD CLASS="l">114</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">115</TD><TD>                        catch (IOException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">116</TD><TD>                                Logger.logException(e);</TD></TR><TR><TD CLASS="l">117</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">118</TD><TD>                        finally {</TD></TR><TR CLASS="z"><TD CLASS="l">119</TD><TD>                                if (reader != null) {</TD></TR><TR><TD CLASS="l">120</TD><TD>                                        try {</TD></TR><TR CLASS="z"><TD CLASS="l">121</TD><TD>                                                reader.close();</TD></TR><TR><TD CLASS="l">122</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">123</TD><TD>                                        catch (IOException e1) {</TD></TR><TR><TD CLASS="l">124</TD><TD>                                                // would be highly unusual</TD></TR><TR CLASS="z"><TD CLASS="l">125</TD><TD>                                                Logger.logException(e1);</TD></TR><TR><TD CLASS="l">126</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">127</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">128</TD><TD>                        }</TD></TR><TR><TD CLASS="l">129</TD><TD> </TD></TR><TR><TD CLASS="l">130</TD><TD>                        // forward the event</TD></TR><TR CLASS="z"><TD CLASS="l">131</TD><TD>                        if (info.fCanBeSaved) {</TD></TR><TR CLASS="z"><TD CLASS="l">132</TD><TD>                                info.fCanBeSaved = false;</TD></TR><TR CLASS="z"><TD CLASS="l">133</TD><TD>                                addUnchangedElementListeners(element, info);</TD></TR><TR><TD CLASS="l">134</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">135</TD><TD>                        fireElementContentReplaced(element);</TD></TR><TR CLASS="z"><TD CLASS="l">136</TD><TD>                        fireElementDirtyStateChanged(element, false);</TD></TR><TR><TD CLASS="l">137</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">138</TD><TD>                        if (info != null &amp;&amp; info.fModel != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">139</TD><TD>                                info.fModel.connect(info.fDocument);</TD></TR><TR><TD CLASS="l"><A NAME="1b">140</A></TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">141</TD><TD>                }</TD></TR><TR><TD CLASS="l">142</TD><TD> </TD></TR><TR><TD CLASS="l">143</TD><TD>                public void elementDeleted(Object element) {</TD></TR><TR CLASS="z"><TD CLASS="l">144</TD><TD>                        if (debugElementStatelistener) {</TD></TR><TR CLASS="z"><TD CLASS="l">145</TD><TD>                                System.out.println(&#34;StorageModelProvider: elementDeleted: &#34; + ((IEditorInput) element).getName()); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">146</TD><TD>                        }</TD></TR><TR><TD CLASS="l">147</TD><TD>                        // we just forward the event</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="1c">148</A></TD><TD>                        StorageModelProvider.this.fireElementDeleted(element);</TD></TR><TR CLASS="z"><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 void elementDirtyStateChanged(Object element, boolean isDirty) {</TD></TR><TR CLASS="z"><TD CLASS="l">152</TD><TD>                        if (debugElementStatelistener) {</TD></TR><TR CLASS="z"><TD CLASS="l">153</TD><TD>                                System.out.println(&#34;StorageModelProvider: elementDirtyStateChanged: &#34; + ((IEditorInput) element).getName() + &#34; (&#34; + isDirty + &#34;)&#34;); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$</TD></TR><TR><TD CLASS="l">154</TD><TD>                        }</TD></TR><TR><TD CLASS="l">155</TD><TD>                        // we just forward the event</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="1d">156</A></TD><TD>                        StorageModelProvider.this.fireElementDirtyStateChanged(element, isDirty);</TD></TR><TR CLASS="z"><TD CLASS="l">157</TD><TD>                }</TD></TR><TR><TD CLASS="l">158</TD><TD> </TD></TR><TR><TD CLASS="l">159</TD><TD>                public void elementMoved(Object originalElement, Object movedElement) {</TD></TR><TR CLASS="z"><TD CLASS="l">160</TD><TD>                        if (debugElementStatelistener) {</TD></TR><TR CLASS="z"><TD CLASS="l">161</TD><TD>                                System.out.println(&#34;StorageModelProvider: elementMoved &#34; + originalElement + &#34; --&gt; &#34; + movedElement); //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR><TD CLASS="l">162</TD><TD>                        }</TD></TR><TR><TD CLASS="l">163</TD><TD>                        // we just forward the event</TD></TR><TR CLASS="z"><TD CLASS="l">164</TD><TD>                        StorageModelProvider.this.fireElementMoved(originalElement, movedElement);</TD></TR><TR CLASS="z"><TD CLASS="l">165</TD><TD>                }</TD></TR><TR><TD CLASS="l">166</TD><TD>        }</TD></TR><TR><TD CLASS="l">167</TD><TD> </TD></TR><TR><TD CLASS="l">168</TD><TD>        /**</TD></TR><TR><TD CLASS="l">169</TD><TD>         * Collection of info that goes with a model.</TD></TR><TR><TD CLASS="l">170</TD><TD>         */</TD></TR><TR><TD CLASS="l">171</TD><TD>        private class ModelInfo {</TD></TR><TR><TD CLASS="l"><A NAME="1e">172</A></TD><TD>                public IEditorInput fElement;</TD></TR><TR><TD CLASS="l">173</TD><TD>                public boolean fShouldReleaseOnInfoDispose;</TD></TR><TR><TD CLASS="l">174</TD><TD>                public IStructuredModel fStructuredModel;</TD></TR><TR><TD CLASS="l">175</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">176</TD><TD>                public ModelInfo(IStructuredModel structuredModel, IEditorInput element, boolean selfCreated) {</TD></TR><TR CLASS="z"><TD CLASS="l">177</TD><TD>                        fElement = element;</TD></TR><TR CLASS="z"><TD CLASS="l">178</TD><TD>                        fStructuredModel = structuredModel;</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="0">179</A></TD><TD>                        fShouldReleaseOnInfoDispose = selfCreated;</TD></TR><TR CLASS="z"><TD CLASS="l">180</TD><TD>                }</TD></TR><TR><TD CLASS="l">181</TD><TD>        }</TD></TR><TR><TD CLASS="l">182</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">183</TD><TD>        static final boolean debugElementStatelistener = &#34;true&#34;.equalsIgnoreCase(Platform.getDebugOption(&#34;org.eclipse.wst.sse.ui/storagemodelprovider/elementstatelistener&#34;)); //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR CLASS="z"><TD CLASS="l">184</TD><TD>        static final boolean debugOperations = &#34;true&#34;.equalsIgnoreCase(Platform.getDebugOption(&#34;org.eclipse.wst.sse.ui/storagemodelprovider/operations&#34;)); //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR><TD CLASS="l"><A NAME="e">185</A></TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">186</TD><TD>        private static StorageModelProvider fInstance = null;</TD></TR><TR><TD CLASS="l">187</TD><TD> </TD></TR><TR><TD CLASS="l">188</TD><TD>        public synchronized static StorageModelProvider getInstance() {</TD></TR><TR CLASS="z"><TD CLASS="l">189</TD><TD>                if (fInstance == null)</TD></TR><TR CLASS="z"><TD CLASS="l">190</TD><TD>                        fInstance = new StorageModelProvider();</TD></TR><TR CLASS="z"><TD CLASS="l">191</TD><TD>                return fInstance;</TD></TR><TR><TD CLASS="l">192</TD><TD>        }</TD></TR><TR><TD CLASS="l">193</TD><TD> </TD></TR><TR><TD CLASS="l">194</TD><TD>        private IElementStateListener fInternalListener;</TD></TR><TR><TD CLASS="l">195</TD><TD>        /** IStructuredModel information of all connected elements */</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="2">196</A></TD><TD>        private Map fModelInfoMap = new HashMap();</TD></TR><TR CLASS="z"><TD CLASS="l">197</TD><TD>        private boolean fReuseModelDocument = true;</TD></TR><TR><TD CLASS="l">198</TD><TD> </TD></TR><TR><TD CLASS="l">199</TD><TD>        private StorageModelProvider() {</TD></TR><TR CLASS="z"><TD CLASS="l">200</TD><TD>                super();</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="3">201</A></TD><TD>                fInternalListener = new InternalElementStateListener();</TD></TR><TR CLASS="z"><TD CLASS="l">202</TD><TD>        }</TD></TR><TR><TD CLASS="l">203</TD><TD> </TD></TR><TR><TD CLASS="l">204</TD><TD>        String calculateBaseLocation(IStorageEditorInput input) {</TD></TR><TR CLASS="z"><TD CLASS="l">205</TD><TD>                String location = null;</TD></TR><TR><TD CLASS="l">206</TD><TD>                try {</TD></TR><TR CLASS="z"><TD CLASS="l">207</TD><TD>                        IStorage storage = input.getStorage();</TD></TR><TR CLASS="z"><TD CLASS="l">208</TD><TD>                        if (storage != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">209</TD><TD>                                IPath storagePath = storage.getFullPath();</TD></TR><TR CLASS="z"><TD CLASS="l">210</TD><TD>                                String name = storage.getName();</TD></TR><TR CLASS="z"><TD CLASS="l">211</TD><TD>                                if (storagePath != null) {</TD></TR><TR><TD CLASS="l">212</TD><TD>                                        // If they are different, the IStorage contract is not</TD></TR><TR><TD CLASS="l">213</TD><TD>                                        // being honored</TD></TR><TR><TD CLASS="l">214</TD><TD>                                        // (https://bugs.eclipse.org/bugs/show_bug.cgi?id=73098).</TD></TR><TR><TD CLASS="l">215</TD><TD>                                        // Favor the name.</TD></TR><TR CLASS="z"><TD CLASS="l">216</TD><TD>                                        if (!storagePath.lastSegment().equals(name)) {</TD></TR><TR CLASS="z"><TD CLASS="l">217</TD><TD>                                                IPath workingPath = storagePath.addTrailingSeparator();</TD></TR><TR CLASS="z"><TD CLASS="l">218</TD><TD>                                                location = workingPath.append(name).toString();</TD></TR><TR><TD CLASS="l">219</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">220</TD><TD>                                        else {</TD></TR><TR CLASS="z"><TD CLASS="l">221</TD><TD>                                                location = storagePath.makeAbsolute().toString();</TD></TR><TR><TD CLASS="l">222</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">223</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">224</TD><TD>                                if (location == null)</TD></TR><TR CLASS="z"><TD CLASS="l">225</TD><TD>                                        location = name;</TD></TR><TR><TD CLASS="l">226</TD><TD>                        }</TD></TR><TR><TD CLASS="l">227</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">228</TD><TD>                catch (CoreException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">229</TD><TD>                        Logger.logException(e);</TD></TR><TR><TD CLASS="l">230</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">231</TD><TD>                finally {</TD></TR><TR CLASS="z"><TD CLASS="l">232</TD><TD>                        if (location == null)</TD></TR><TR CLASS="z"><TD CLASS="l">233</TD><TD>                                location = input.getName();</TD></TR><TR CLASS="z"><TD CLASS="l">234</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">235</TD><TD>                return location;</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>        String calculateID(IStorageEditorInput input) {</TD></TR><TR><TD CLASS="l">239</TD><TD>                /**</TD></TR><TR><TD CLASS="l">240</TD><TD>                 * Typically CVS will return a path of &#34;filename.ext&#34; and the input's</TD></TR><TR><TD CLASS="l">241</TD><TD>                 * name will be &#34;filename.ext version&#34;. The path must be used to load</TD></TR><TR><TD CLASS="l">242</TD><TD>                 * the model so that the suffix will be available to compute the</TD></TR><TR><TD CLASS="l"><A NAME="4">243</A></TD><TD>                 * contentType properly. The editor input name can then be set as the</TD></TR><TR><TD CLASS="l">244</TD><TD>                 * base location for display on the editor title bar.</TD></TR><TR><TD CLASS="l">245</TD><TD>                 * </TD></TR><TR><TD CLASS="l">246</TD><TD>                 */</TD></TR><TR CLASS="z"><TD CLASS="l">247</TD><TD>                String path = null;</TD></TR><TR><TD CLASS="l">248</TD><TD>                try {</TD></TR><TR CLASS="z"><TD CLASS="l">249</TD><TD>                        IStorage storage = input.getStorage();</TD></TR><TR CLASS="z"><TD CLASS="l">250</TD><TD>                        if (storage != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">251</TD><TD>                                IPath storagePath = storage.getFullPath();</TD></TR><TR CLASS="z"><TD CLASS="l">252</TD><TD>                                String name = storage.getName();</TD></TR><TR CLASS="z"><TD CLASS="l">253</TD><TD>                                if (storagePath != null) {</TD></TR><TR><TD CLASS="l">254</TD><TD>                                        // If they are different, the IStorage contract is not</TD></TR><TR><TD CLASS="l">255</TD><TD>                                        // being honored</TD></TR><TR><TD CLASS="l">256</TD><TD>                                        // (https://bugs.eclipse.org/bugs/show_bug.cgi?id=73098).</TD></TR><TR><TD CLASS="l">257</TD><TD>                                        // Favor the name.</TD></TR><TR CLASS="z"><TD CLASS="l">258</TD><TD>                                        if (!storagePath.lastSegment().equals(name)) {</TD></TR><TR CLASS="z"><TD CLASS="l">259</TD><TD>                                                IPath workingPath = storagePath.addTrailingSeparator();</TD></TR><TR CLASS="z"><TD CLASS="l">260</TD><TD>                                                path = workingPath.append(name).toString();</TD></TR><TR><TD CLASS="l">261</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">262</TD><TD>                                        else {</TD></TR><TR CLASS="z"><TD CLASS="l">263</TD><TD>                                                path = storagePath.makeAbsolute().toString();</TD></TR><TR><TD CLASS="l">264</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">265</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">266</TD><TD>                                if (path == null)</TD></TR><TR CLASS="z"><TD CLASS="l">267</TD><TD>                                        path = name;</TD></TR><TR><TD CLASS="l">268</TD><TD>                        }</TD></TR><TR><TD CLASS="l">269</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">270</TD><TD>                catch (CoreException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">271</TD><TD>                        Logger.logException(e);</TD></TR><TR><TD CLASS="l">272</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">273</TD><TD>                finally {</TD></TR><TR CLASS="z"><TD CLASS="l">274</TD><TD>                        if (path == null)</TD></TR><TR CLASS="z"><TD CLASS="l">275</TD><TD>                                path = &#34;&#34;; //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">276</TD><TD>                }</TD></TR><TR><TD CLASS="l">277</TD><TD>                /*</TD></TR><TR><TD CLASS="l">278</TD><TD>                 * Prepend the hash to the path value so that we have a 1:1:1 match</TD></TR><TR><TD CLASS="l">279</TD><TD>                 * between editor inputs, element info, and models. The editor manager</TD></TR><TR><TD CLASS="l">280</TD><TD>                 * should help prevent needlessly duplicated models as long as two</TD></TR><TR><TD CLASS="l">281</TD><TD>                 * editor inputs from the same storage indicate they're equals().</TD></TR><TR><TD CLASS="l">282</TD><TD>                 */</TD></TR><TR CLASS="z"><TD CLASS="l">283</TD><TD>                path = input.hashCode() + &#34;#&#34; + path; //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">284</TD><TD>                return path;</TD></TR><TR><TD CLASS="l">285</TD><TD>        }</TD></TR><TR><TD CLASS="l">286</TD><TD> </TD></TR><TR><TD CLASS="l">287</TD><TD>        // public boolean canSaveDocument(Object element) {</TD></TR><TR><TD CLASS="l"><A NAME="5">288</A></TD><TD>        // return false;</TD></TR><TR><TD CLASS="l">289</TD><TD>        // }</TD></TR><TR><TD CLASS="l">290</TD><TD> </TD></TR><TR><TD CLASS="l">291</TD><TD>        protected IAnnotationModel createAnnotationModel(Object element) throws CoreException {</TD></TR><TR CLASS="z"><TD CLASS="l">292</TD><TD>                IAnnotationModel model = null;</TD></TR><TR CLASS="z"><TD CLASS="l">293</TD><TD>                if (debugOperations) {</TD></TR><TR CLASS="z"><TD CLASS="l">294</TD><TD>                        if (element instanceof IStorageEditorInput)</TD></TR><TR CLASS="z"><TD CLASS="l">295</TD><TD>                                System.out.println(&#34;StorageModelProvider: createAnnotationModel for &#34; + ((IStorageEditorInput) element).getStorage().getFullPath()); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">296</TD><TD>                        else</TD></TR><TR CLASS="z"><TD CLASS="l">297</TD><TD>                                System.out.println(&#34;StorageModelProvider: createAnnotationModel for &#34; + element); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">298</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">299</TD><TD>                if (element instanceof IStorageEditorInput) {</TD></TR><TR CLASS="z"><TD CLASS="l">300</TD><TD>                        IStorageEditorInput input = (IStorageEditorInput) element;</TD></TR><TR CLASS="z"><TD CLASS="l">301</TD><TD>                        String contentType = (getModel(input) != null ? getModel(input).getContentTypeIdentifier() : null);</TD></TR><TR CLASS="z"><TD CLASS="l">302</TD><TD>                        String ext = BreakpointRulerAction.getFileExtension((IEditorInput) element);</TD></TR><TR CLASS="z"><TD CLASS="l">303</TD><TD>                        IResource res = BreakpointProviderBuilder.getInstance().getResource(input, contentType, ext);</TD></TR><TR CLASS="z"><TD CLASS="l">304</TD><TD>                        String id = input.getName();</TD></TR><TR CLASS="z"><TD CLASS="l">305</TD><TD>                        if (input.getStorage() != null &amp;&amp; input.getStorage().getFullPath() != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">306</TD><TD>                                id = input.getStorage().getFullPath().toString();</TD></TR><TR><TD CLASS="l">307</TD><TD>                        }</TD></TR><TR><TD CLASS="l">308</TD><TD>                        // we can only create a resource marker annotationmodel off of a</TD></TR><TR><TD CLASS="l">309</TD><TD>                        // valid resource</TD></TR><TR CLASS="z"><TD CLASS="l">310</TD><TD>                        if (res != null)</TD></TR><TR CLASS="z"><TD CLASS="l">311</TD><TD>                                model = new StructuredResourceMarkerAnnotationModel(res, id);</TD></TR><TR><TD CLASS="l">312</TD><TD>                        else</TD></TR><TR CLASS="z"><TD CLASS="l">313</TD><TD>                                model = new AnnotationModel();</TD></TR><TR><TD CLASS="l">314</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">315</TD><TD>                if (model == null) {</TD></TR><TR CLASS="z"><TD CLASS="l">316</TD><TD>                        model = super.createAnnotationModel(element);</TD></TR><TR><TD CLASS="l">317</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="6">318</A></TD><TD>                return model;</TD></TR><TR><TD CLASS="l">319</TD><TD>        }</TD></TR><TR><TD CLASS="l">320</TD><TD> </TD></TR><TR><TD CLASS="l">321</TD><TD>        protected IDocument createDocument(Object element) {</TD></TR><TR CLASS="z"><TD CLASS="l">322</TD><TD>                if (debugOperations) {</TD></TR><TR CLASS="z"><TD CLASS="l">323</TD><TD>                        if (element instanceof IStorageEditorInput)</TD></TR><TR><TD CLASS="l">324</TD><TD>                                try {</TD></TR><TR CLASS="z"><TD CLASS="l">325</TD><TD>                                        System.out.println(&#34;StorageModelProvider: createDocument for &#34; + ((IStorageEditorInput) element).getStorage().getFullPath()); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">326</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">327</TD><TD>                                catch (CoreException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">328</TD><TD>                                        System.out.println(&#34;StorageModelProvider: createDocument for &#34; + element + &#34;(exception caught)&#34;); //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR><TD CLASS="l">329</TD><TD>                                }</TD></TR><TR><TD CLASS="l">330</TD><TD>                        else {</TD></TR><TR CLASS="z"><TD CLASS="l">331</TD><TD>                                System.out.println(&#34;StorageModelProvider: createDocument for &#34; + element); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">332</TD><TD>                        }</TD></TR><TR><TD CLASS="l">333</TD><TD>                }</TD></TR><TR><TD CLASS="l">334</TD><TD> </TD></TR><TR><TD CLASS="l">335</TD><TD>                // The following is largely copied from FileModelProvider</TD></TR><TR><TD CLASS="l">336</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">337</TD><TD>                IDocument document = null;</TD></TR><TR CLASS="z"><TD CLASS="l">338</TD><TD>                if (element instanceof IEditorInput) {</TD></TR><TR><TD CLASS="l">339</TD><TD>                        // create a new IDocument for the element; should always reflect</TD></TR><TR><TD CLASS="l">340</TD><TD>                        // the contents of the resource</TD></TR><TR CLASS="z"><TD CLASS="l">341</TD><TD>                        ModelInfo info = getModelInfoFor((IEditorInput) element);</TD></TR><TR CLASS="z"><TD CLASS="l">342</TD><TD>                        if (info == null) {</TD></TR><TR CLASS="z"><TD CLASS="l">343</TD><TD>                                throw new IllegalArgumentException(&#34;no corresponding model info found&#34;); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">344</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">345</TD><TD>                        IStructuredModel model = info.fStructuredModel;</TD></TR><TR CLASS="z"><TD CLASS="l">346</TD><TD>                        if (model != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">347</TD><TD>                                if (!fReuseModelDocument &amp;&amp; element instanceof IStorageEditorInput) {</TD></TR><TR CLASS="z"><TD CLASS="l">348</TD><TD>                                        Reader reader = null;</TD></TR><TR CLASS="z"><TD CLASS="l">349</TD><TD>                                        IStructuredDocument innerdocument = null;</TD></TR><TR><TD CLASS="l">350</TD><TD>                                        try {</TD></TR><TR><TD CLASS="l">351</TD><TD>                                                // update document from input's contents</TD></TR><TR><TD CLASS="l">352</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">353</TD><TD>                                                CodedReaderCreator codedReaderCreator = new CodedReaderCreator(calculateID((IStorageEditorInput) element), Utilities.getMarkSupportedStream(((IStorageEditorInput) element).getStorage().getContents()));</TD></TR><TR CLASS="z"><TD CLASS="l">354</TD><TD>                                                reader = codedReaderCreator.getCodedReader();</TD></TR><TR><TD CLASS="l">355</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">356</TD><TD>                                                innerdocument = model.getStructuredDocument();</TD></TR><TR><TD CLASS="l">357</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">358</TD><TD>                                                int originalLengthToReplace = innerdocument.getLength();</TD></TR><TR><TD CLASS="l">359</TD><TD> </TD></TR><TR><TD CLASS="l">360</TD><TD>                                                /*</TD></TR><TR><TD CLASS="l">361</TD><TD>                                                 * TODO_future: we could implement with sequential</TD></TR><TR><TD CLASS="l">362</TD><TD>                                                 * rewrite, if we don't pickup automatically from</TD></TR><TR><TD CLASS="l">363</TD><TD>                                                 * FileBuffer support, so not so much has to be pulled</TD></TR><TR><TD CLASS="l">364</TD><TD>                                                 * into memory (as an extra big string), but we need</TD></TR><TR><TD CLASS="l">365</TD><TD>                                                 * to carry that API through so that StructuredModel</TD></TR><TR><TD CLASS="l">366</TD><TD>                                                 * is not notified until done.</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>                                                // innerdocument.startSequentialRewrite(true);</TD></TR><TR><TD CLASS="l">370</TD><TD>                                                // innerdocument.replaceText(this, 0,</TD></TR><TR><TD CLASS="l">371</TD><TD>                                                // innerdocument.getLength(), &#34;&#34;);</TD></TR><TR CLASS="z"><TD CLASS="l">372</TD><TD>                                                StringBuffer stringBuffer = new StringBuffer();</TD></TR><TR CLASS="z"><TD CLASS="l">373</TD><TD>                                                int bufferSize = 2048;</TD></TR><TR CLASS="z"><TD CLASS="l">374</TD><TD>                                                char[] buffer = new char[bufferSize];</TD></TR><TR CLASS="z"><TD CLASS="l">375</TD><TD>                                                int nRead = 0;</TD></TR><TR CLASS="z"><TD CLASS="l">376</TD><TD>                                                boolean eof = false;</TD></TR><TR CLASS="z"><TD CLASS="l">377</TD><TD>                                                while (!eof) {</TD></TR><TR CLASS="z"><TD CLASS="l">378</TD><TD>                                                        nRead = reader.read(buffer, 0, bufferSize);</TD></TR><TR CLASS="z"><TD CLASS="l">379</TD><TD>                                                        if (nRead == -1) {</TD></TR><TR CLASS="z"><TD CLASS="l">380</TD><TD>                                                                eof = true;</TD></TR><TR><TD CLASS="l">381</TD><TD>                                                        }</TD></TR><TR><TD CLASS="l">382</TD><TD>                                                        else {</TD></TR><TR CLASS="z"><TD CLASS="l">383</TD><TD>                                                                stringBuffer.append(buffer, 0, nRead);</TD></TR><TR><TD CLASS="l">384</TD><TD>                                                                // innerdocument.replaceText(this,</TD></TR><TR><TD CLASS="l">385</TD><TD>                                                                // innerdocument.getLength(), 0, new</TD></TR><TR><TD CLASS="l">386</TD><TD>                                                                // String(buffer, 0, nRead));</TD></TR><TR><TD CLASS="l">387</TD><TD>                                                        }</TD></TR><TR><TD CLASS="l">388</TD><TD>                                                }</TD></TR><TR><TD CLASS="l">389</TD><TD>                                                // ignore read-only settings if reverting whole</TD></TR><TR><TD CLASS="l">390</TD><TD>                                                // document</TD></TR><TR CLASS="z"><TD CLASS="l">391</TD><TD>                                                innerdocument.replaceText(this, 0, originalLengthToReplace, stringBuffer.toString(), true);</TD></TR><TR CLASS="z"><TD CLASS="l">392</TD><TD>                                                model.setDirtyState(false);</TD></TR><TR><TD CLASS="l">393</TD><TD> </TD></TR><TR><TD CLASS="l">394</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">395</TD><TD>                                        catch (CoreException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">396</TD><TD>                                                Logger.logException(e);</TD></TR><TR><TD CLASS="l">397</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">398</TD><TD>                                        catch (IOException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">399</TD><TD>                                                Logger.logException(e);</TD></TR><TR><TD CLASS="l">400</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">401</TD><TD>                                        finally {</TD></TR><TR CLASS="z"><TD CLASS="l">402</TD><TD>                                                if (reader != null) {</TD></TR><TR><TD CLASS="l">403</TD><TD>                                                        try {</TD></TR><TR CLASS="z"><TD CLASS="l">404</TD><TD>                                                                reader.close();</TD></TR><TR><TD CLASS="l">405</TD><TD>                                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">406</TD><TD>                                                        catch (IOException e1) {</TD></TR><TR><TD CLASS="l">407</TD><TD>                                                                // would be highly unusual</TD></TR><TR CLASS="z"><TD CLASS="l">408</TD><TD>                                                                Logger.logException(e1);</TD></TR><TR><TD CLASS="l">409</TD><TD>                                                        }</TD></TR><TR><TD CLASS="l">410</TD><TD>                                                }</TD></TR><TR><TD CLASS="l">411</TD><TD>                                                // if (innerdocument != null) {</TD></TR><TR><TD CLASS="l">412</TD><TD>                                                // innerdocument.stopSequentialRewrite();</TD></TR><TR><TD CLASS="l">413</TD><TD>                                                // }</TD></TR><TR CLASS="z"><TD CLASS="l">414</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">415</TD><TD> </TD></TR><TR><TD CLASS="l">416</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">417</TD><TD>                                if (document == null) {</TD></TR><TR CLASS="z"><TD CLASS="l">418</TD><TD>                                        document = model.getStructuredDocument();</TD></TR><TR><TD CLASS="l">419</TD><TD>                                }</TD></TR><TR><TD CLASS="l">420</TD><TD>                        }</TD></TR><TR><TD CLASS="l">421</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">422</TD><TD>                return document;</TD></TR><TR><TD CLASS="l">423</TD><TD>        }</TD></TR><TR><TD CLASS="l">424</TD><TD> </TD></TR><TR><TD CLASS="l">425</TD><TD>        /**</TD></TR><TR><TD CLASS="l">426</TD><TD>         * Also create ModelInfo - extra resource synchronization classes should</TD></TR><TR><TD CLASS="l"><A NAME="7">427</A></TD><TD>         * be stored within the ModelInfo</TD></TR><TR><TD CLASS="l">428</TD><TD>         */</TD></TR><TR><TD CLASS="l">429</TD><TD>        protected ElementInfo createElementInfo(Object element) throws CoreException {</TD></TR><TR><TD CLASS="l">430</TD><TD>                // create the corresponding ModelInfo if necessary</TD></TR><TR CLASS="z"><TD CLASS="l">431</TD><TD>                if (debugOperations) {</TD></TR><TR CLASS="z"><TD CLASS="l">432</TD><TD>                        if (element instanceof IStorageEditorInput)</TD></TR><TR><TD CLASS="l">433</TD><TD>                                try {</TD></TR><TR CLASS="z"><TD CLASS="l">434</TD><TD>                                        System.out.println(&#34;StorageModelProvider: createElementInfo for &#34; + ((IStorageEditorInput) element).getStorage().getFullPath()); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">435</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">436</TD><TD>                                catch (CoreException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">437</TD><TD>                                        System.out.println(&#34;StorageModelProvider: createElementInfo for &#34; + element + &#34;(exception caught)&#34;); //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR><TD CLASS="l">438</TD><TD>                                }</TD></TR><TR><TD CLASS="l">439</TD><TD>                        else</TD></TR><TR CLASS="z"><TD CLASS="l">440</TD><TD>                                System.out.println(&#34;storageModelProvider: createElementInfo for &#34; + element); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">441</TD><TD>                }</TD></TR><TR><TD CLASS="l">442</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">443</TD><TD>                if (getModelInfoFor((IEditorInput) element) == null) {</TD></TR><TR CLASS="z"><TD CLASS="l">444</TD><TD>                        createModelInfo((IEditorInput) element);</TD></TR><TR><TD CLASS="l">445</TD><TD>                }</TD></TR><TR><TD CLASS="l">446</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">447</TD><TD>                ElementInfo info = super.createElementInfo(element);</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="8">448</A></TD><TD>                return info;</TD></TR><TR><TD CLASS="l">449</TD><TD>        }</TD></TR><TR><TD CLASS="l">450</TD><TD> </TD></TR><TR><TD CLASS="l">451</TD><TD>        public void createModelInfo(IEditorInput input) {</TD></TR><TR CLASS="z"><TD CLASS="l">452</TD><TD>                if (getModelInfoFor(input) == null) {</TD></TR><TR CLASS="z"><TD CLASS="l">453</TD><TD>                        IStructuredModel structuredModel = selfCreateModel(input);</TD></TR><TR CLASS="z"><TD CLASS="l">454</TD><TD>                        if (structuredModel != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">455</TD><TD>                                createModelInfo(input, structuredModel, true);</TD></TR><TR><TD CLASS="l">456</TD><TD>                        }</TD></TR><TR><TD CLASS="l">457</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">458</TD><TD>        }</TD></TR><TR><TD CLASS="l">459</TD><TD> </TD></TR><TR><TD CLASS="l">460</TD><TD>        /**</TD></TR><TR><TD CLASS="l">461</TD><TD>         * To be used when model is provided to us, ensures that when setInput is</TD></TR><TR><TD CLASS="l">462</TD><TD>         * used on this input, the given model will be used.</TD></TR><TR><TD CLASS="l"><A NAME="9">463</A></TD><TD>         */</TD></TR><TR><TD CLASS="l">464</TD><TD>        public void createModelInfo(IEditorInput input, IStructuredModel structuredModel, boolean releaseModelOnDisconnect) {</TD></TR><TR><TD CLASS="l">465</TD><TD>                // we have to make sure factories are added, whether we created or</TD></TR><TR><TD CLASS="l">466</TD><TD>                // not.</TD></TR><TR CLASS="z"><TD CLASS="l">467</TD><TD>                if (getModelInfoFor(input) != null || getModelInfoFor(structuredModel) != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">468</TD><TD>                        if (debugOperations) {</TD></TR><TR CLASS="z"><TD CLASS="l">469</TD><TD>                                if (input instanceof IStorageEditorInput) {</TD></TR><TR><TD CLASS="l">470</TD><TD> </TD></TR><TR><TD CLASS="l">471</TD><TD>                                        try {</TD></TR><TR CLASS="z"><TD CLASS="l">472</TD><TD>                                                System.out.println(&#34;StorageModelProvider: DUPLICATE createModelInfo for &#34; + ((IStorageEditorInput) input).getStorage().getFullPath()); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">473</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">474</TD><TD>                                        catch (CoreException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">475</TD><TD>                                                System.out.println(&#34;StorageModelProvider: DUPLICATE createModelInfo for &#34; + input + &#34;(exception caught)&#34;); //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR><TD CLASS="l">476</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">477</TD><TD>                                }</TD></TR><TR><TD CLASS="l">478</TD><TD>                                else {</TD></TR><TR CLASS="z"><TD CLASS="l">479</TD><TD>                                        System.out.println(&#34;storageModelProvider: DUPLICATE createModelInfo for &#34; + input); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">480</TD><TD>                                }</TD></TR><TR><TD CLASS="l">481</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">482</TD><TD>                        return;</TD></TR><TR><TD CLASS="l">483</TD><TD>                }</TD></TR><TR><TD CLASS="l">484</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">485</TD><TD>                if (debugOperations) {</TD></TR><TR CLASS="z"><TD CLASS="l">486</TD><TD>                        if (input instanceof IStorageEditorInput) {</TD></TR><TR><TD CLASS="l">487</TD><TD>                                try {</TD></TR><TR CLASS="z"><TD CLASS="l">488</TD><TD>                                        System.out.println(&#34;StorageModelProvider: createModelInfo for &#34; + ((IStorageEditorInput) input).getStorage().getFullPath()); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">489</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">490</TD><TD>                                catch (CoreException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">491</TD><TD>                                        System.out.println(&#34;StorageModelProvider: createModelInfo for &#34; + input + &#34;(exception caught)&#34;); //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR><TD CLASS="l">492</TD><TD>                                }</TD></TR><TR><TD CLASS="l">493</TD><TD>                        }</TD></TR><TR><TD CLASS="l">494</TD><TD>                        else {</TD></TR><TR CLASS="z"><TD CLASS="l">495</TD><TD>                                System.out.println(&#34;StorageModelProvider: createModelInfo for &#34; + input); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">496</TD><TD>                        }</TD></TR><TR><TD CLASS="l">497</TD><TD>                }</TD></TR><TR><TD CLASS="l">498</TD><TD> </TD></TR><TR><TD CLASS="l">499</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">500</TD><TD>                if (input instanceof IExtendedStorageEditorInput) {</TD></TR><TR CLASS="z"><TD CLASS="l">501</TD><TD>                        ((IExtendedStorageEditorInput) input).addElementStateListener(fInternalListener);</TD></TR><TR><TD CLASS="l">502</TD><TD>                }</TD></TR><TR><TD CLASS="l">503</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">504</TD><TD>                EditorModelUtil.addFactoriesTo(structuredModel);</TD></TR><TR><TD CLASS="l">505</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">506</TD><TD>                ModelInfo modelInfo = new ModelInfo(structuredModel, input, releaseModelOnDisconnect);</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="a">507</A></TD><TD>                fModelInfoMap.put(input, modelInfo);</TD></TR><TR CLASS="z"><TD CLASS="l">508</TD><TD>        }</TD></TR><TR><TD CLASS="l">509</TD><TD> </TD></TR><TR><TD CLASS="l">510</TD><TD>        protected void disposeElementInfo(Object element, ElementInfo info) {</TD></TR><TR CLASS="z"><TD CLASS="l">511</TD><TD>                if (debugOperations) {</TD></TR><TR CLASS="z"><TD CLASS="l">512</TD><TD>                        if (element instanceof IStorageEditorInput) {</TD></TR><TR><TD CLASS="l">513</TD><TD>                                try {</TD></TR><TR CLASS="z"><TD CLASS="l">514</TD><TD>                                        System.out.println(&#34;StorageModelProvider: disposeElementInfo for &#34; + ((IStorageEditorInput) element).getStorage().getFullPath()); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">515</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">516</TD><TD>                                catch (CoreException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">517</TD><TD>                                        System.out.println(&#34;StorageModelProvider: disposeElementInfo for &#34; + element + &#34;(exception caught)&#34;); //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR><TD CLASS="l">518</TD><TD>                                }</TD></TR><TR><TD CLASS="l">519</TD><TD>                        }</TD></TR><TR><TD CLASS="l">520</TD><TD>                        else {</TD></TR><TR CLASS="z"><TD CLASS="l">521</TD><TD>                                System.out.println(&#34;StorageModelProvider: disposeElementInfo for &#34; + element); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">522</TD><TD>                        }</TD></TR><TR><TD CLASS="l">523</TD><TD>                }</TD></TR><TR><TD CLASS="l">524</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">525</TD><TD>                if (element instanceof IEditorInput) {</TD></TR><TR CLASS="z"><TD CLASS="l">526</TD><TD>                        IEditorInput input = (IEditorInput) element;</TD></TR><TR CLASS="z"><TD CLASS="l">527</TD><TD>                        ModelInfo modelInfo = getModelInfoFor(input);</TD></TR><TR CLASS="z"><TD CLASS="l">528</TD><TD>                        disposeModelInfo(modelInfo);</TD></TR><TR><TD CLASS="l">529</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">530</TD><TD>                super.disposeElementInfo(element, info);</TD></TR><TR CLASS="z"><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>         * disconnect from this model info</TD></TR><TR><TD CLASS="l"><A NAME="b">535</A></TD><TD>         * </TD></TR><TR><TD CLASS="l">536</TD><TD>         * @param info</TD></TR><TR><TD CLASS="l">537</TD><TD>         */</TD></TR><TR><TD CLASS="l">538</TD><TD>        public void disposeModelInfo(ModelInfo info) {</TD></TR><TR CLASS="z"><TD CLASS="l">539</TD><TD>                if (debugOperations) {</TD></TR><TR CLASS="z"><TD CLASS="l">540</TD><TD>                        if (info.fElement instanceof IStorageEditorInput) {</TD></TR><TR><TD CLASS="l">541</TD><TD>                                try {</TD></TR><TR CLASS="z"><TD CLASS="l">542</TD><TD>                                        System.out.println(&#34;StorageModelProvider: disposeModelInfo for &#34; + ((IStorageEditorInput) info.fElement).getStorage().getFullPath()); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">543</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">544</TD><TD>                                catch (CoreException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">545</TD><TD>                                        System.out.println(&#34;StorageModelProvider: disposeModelInfo for &#34; + info.fElement + &#34;(exception caught)&#34;); //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR><TD CLASS="l">546</TD><TD>                                }</TD></TR><TR><TD CLASS="l">547</TD><TD>                        }</TD></TR><TR><TD CLASS="l">548</TD><TD>                        else {</TD></TR><TR CLASS="z"><TD CLASS="l">549</TD><TD>                                System.out.println(&#34;StorageModelProvider: disposeModelInfo for &#34; + info.fElement); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">550</TD><TD>                        }</TD></TR><TR><TD CLASS="l">551</TD><TD>                }</TD></TR><TR><TD CLASS="l">552</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">553</TD><TD>                if (info.fElement instanceof IStorageEditorInput) {</TD></TR><TR CLASS="z"><TD CLASS="l">554</TD><TD>                        if (info.fElement instanceof IExtendedStorageEditorInput) {</TD></TR><TR CLASS="z"><TD CLASS="l">555</TD><TD>                                ((IExtendedStorageEditorInput) info.fElement).removeElementStateListener(fInternalListener);</TD></TR><TR><TD CLASS="l">556</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">557</TD><TD>                        if (info.fShouldReleaseOnInfoDispose) {</TD></TR><TR CLASS="z"><TD CLASS="l">558</TD><TD>                                info.fStructuredModel.releaseFromEdit();</TD></TR><TR><TD CLASS="l">559</TD><TD>                        }</TD></TR><TR><TD CLASS="l">560</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">561</TD><TD>                fModelInfoMap.remove(info.fElement);</TD></TR><TR CLASS="z"><TD CLASS="l">562</TD><TD>        }</TD></TR><TR><TD CLASS="l">563</TD><TD> </TD></TR><TR><TD CLASS="l">564</TD><TD>        /*</TD></TR><TR><TD CLASS="l">565</TD><TD>         * (non-Javadoc)</TD></TR><TR><TD CLASS="l">566</TD><TD>         * </TD></TR><TR><TD CLASS="l"><A NAME="c">567</A></TD><TD>         * @see org.eclipse.ui.texteditor.AbstractDocumentProvider#doResetDocument(java.lang.Object,</TD></TR><TR><TD CLASS="l">568</TD><TD>         *      org.eclipse.core.runtime.IProgressMonitor)</TD></TR><TR><TD CLASS="l">569</TD><TD>         */</TD></TR><TR><TD CLASS="l">570</TD><TD>        protected void doResetDocument(Object element, IProgressMonitor monitor) throws CoreException {</TD></TR><TR CLASS="z"><TD CLASS="l">571</TD><TD>                fReuseModelDocument = false;</TD></TR><TR CLASS="z"><TD CLASS="l">572</TD><TD>                super.doResetDocument(element, monitor);</TD></TR><TR CLASS="z"><TD CLASS="l">573</TD><TD>                fReuseModelDocument = true;</TD></TR><TR CLASS="z"><TD CLASS="l">574</TD><TD>        }</TD></TR><TR><TD CLASS="l">575</TD><TD> </TD></TR><TR><TD CLASS="l">576</TD><TD>        /**</TD></TR><TR><TD CLASS="l"><A NAME="d">577</A></TD><TD>         * @see org.eclipse.ui.texteditor.AbstractDocumentProvider#doSaveDocument(org.eclipse.core.runtime.IProgressMonitor,</TD></TR><TR><TD CLASS="l">578</TD><TD>         *      java.lang.Object, org.eclipse.jface.text.IDocument, boolean)</TD></TR><TR><TD CLASS="l">579</TD><TD>         */</TD></TR><TR><TD CLASS="l">580</TD><TD>        protected void doSaveDocument(IProgressMonitor monitor, Object element, IDocument document, boolean overwrite) throws CoreException {</TD></TR><TR CLASS="z"><TD CLASS="l">581</TD><TD>                IDocumentProvider provider = null;</TD></TR><TR><TD CLASS="l">582</TD><TD>                // BUG119211 - try to use registered document provider if possible</TD></TR><TR CLASS="z"><TD CLASS="l">583</TD><TD>                if (element instanceof IEditorInput) {</TD></TR><TR CLASS="z"><TD CLASS="l">584</TD><TD>                        provider = DocumentProviderRegistry.getDefault().getDocumentProvider((IEditorInput) element);</TD></TR><TR><TD CLASS="l">585</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">586</TD><TD>                if (provider == null)</TD></TR><TR CLASS="z"><TD CLASS="l">587</TD><TD>                        provider = new FileDocumentProvider();</TD></TR><TR CLASS="z"><TD CLASS="l">588</TD><TD>                provider.saveDocument(monitor, element, document, overwrite);</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"><A NAME="13">591</A></TD><TD>        /* (non-Javadoc)</TD></TR><TR><TD CLASS="l">592</TD><TD>         * @see org.eclipse.ui.editors.text.StorageDocumentProvider#getPersistedEncoding(java.lang.Object)</TD></TR><TR><TD CLASS="l">593</TD><TD>         */</TD></TR><TR><TD CLASS="l">594</TD><TD>        protected String getPersistedEncoding(Object element) {</TD></TR><TR CLASS="z"><TD CLASS="l">595</TD><TD>                if (element instanceof IStorageEditorInput) {</TD></TR><TR><TD CLASS="l">596</TD><TD>                        IStorage storage;</TD></TR><TR><TD CLASS="l">597</TD><TD>                        try {</TD></TR><TR CLASS="z"><TD CLASS="l">598</TD><TD>                                storage = ((IStorageEditorInput) element).getStorage();</TD></TR><TR CLASS="z"><TD CLASS="l">599</TD><TD>                                if (storage != null &amp;&amp; !(storage instanceof IEncodedStorage)) {</TD></TR><TR CLASS="z"><TD CLASS="l">600</TD><TD>                                        InputStream contents = null;</TD></TR><TR><TD CLASS="l">601</TD><TD>                                        try {</TD></TR><TR CLASS="z"><TD CLASS="l">602</TD><TD>                                                contents = storage.getContents();</TD></TR><TR CLASS="z"><TD CLASS="l">603</TD><TD>                                                if (contents != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">604</TD><TD>                                                        QualifiedName[] detectionOptions = new QualifiedName[]{IContentDescription.BYTE_ORDER_MARK, IContentDescription.CHARSET};</TD></TR><TR CLASS="z"><TD CLASS="l">605</TD><TD>                                                        IContentDescription description = Platform.getContentTypeManager().getDescriptionFor(contents, storage.getName(), detectionOptions);</TD></TR><TR CLASS="z"><TD CLASS="l">606</TD><TD>                                                        String charset = description.getCharset();</TD></TR><TR CLASS="z"><TD CLASS="l">607</TD><TD>                                                        if (charset != null)</TD></TR><TR CLASS="z"><TD CLASS="l">608</TD><TD>                                                                return charset;</TD></TR><TR><TD CLASS="l">609</TD><TD>                                                }</TD></TR><TR><TD CLASS="l">610</TD><TD> </TD></TR><TR><TD CLASS="l">611</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">612</TD><TD>                                        catch (IOException e) {</TD></TR><TR><TD CLASS="l">613</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">614</TD><TD>                                        finally {</TD></TR><TR CLASS="z"><TD CLASS="l">615</TD><TD>                                                if (contents != null)</TD></TR><TR><TD CLASS="l">616</TD><TD>                                                        try {</TD></TR><TR CLASS="z"><TD CLASS="l">617</TD><TD>                                                                contents.close();</TD></TR><TR><TD CLASS="l">618</TD><TD>                                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">619</TD><TD>                                                        catch (IOException e) {</TD></TR><TR><TD CLASS="l">620</TD><TD>                                                                // do nothing</TD></TR><TR><TD CLASS="l">621</TD><TD>                                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">622</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">623</TD><TD>                                }</TD></TR><TR><TD CLASS="l">624</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">625</TD><TD>                        catch (CoreException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">626</TD><TD>                                Logger.logException(e);</TD></TR><TR><TD CLASS="l">627</TD><TD>                        }</TD></TR><TR><TD CLASS="l">628</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="f">629</A></TD><TD>                return super.getPersistedEncoding(element);</TD></TR><TR><TD CLASS="l">630</TD><TD>        }</TD></TR><TR><TD CLASS="l">631</TD><TD> </TD></TR><TR><TD CLASS="l">632</TD><TD>        public IStructuredModel getModel(IEditorInput element) {</TD></TR><TR CLASS="z"><TD CLASS="l">633</TD><TD>                IStructuredModel result = null;</TD></TR><TR CLASS="z"><TD CLASS="l">634</TD><TD>                ModelInfo info = getModelInfoFor(element);</TD></TR><TR CLASS="z"><TD CLASS="l">635</TD><TD>                if (info != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">636</TD><TD>                        result = info.fStructuredModel;</TD></TR><TR><TD CLASS="l">637</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">638</TD><TD>                return result;</TD></TR><TR><TD CLASS="l">639</TD><TD>        }</TD></TR><TR><TD CLASS="l">640</TD><TD> </TD></TR><TR><TD CLASS="l">641</TD><TD>        /*</TD></TR><TR><TD CLASS="l">642</TD><TD>         * (non-Javadoc)</TD></TR><TR><TD CLASS="l"><A NAME="10">643</A></TD><TD>         * </TD></TR><TR><TD CLASS="l">644</TD><TD>         * @see org.eclipse.wst.sse.ui.IModelProvider#getModel(java.lang.Object)</TD></TR><TR><TD CLASS="l">645</TD><TD>         */</TD></TR><TR><TD CLASS="l">646</TD><TD>        public IStructuredModel getModel(Object element) {</TD></TR><TR CLASS="z"><TD CLASS="l">647</TD><TD>                if (element instanceof IEditorInput)</TD></TR><TR CLASS="z"><TD CLASS="l">648</TD><TD>                        return getModel((IEditorInput) element);</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="11">649</A></TD><TD>                return null;</TD></TR><TR><TD CLASS="l">650</TD><TD>        }</TD></TR><TR><TD CLASS="l">651</TD><TD> </TD></TR><TR><TD CLASS="l">652</TD><TD>        private ModelInfo getModelInfoFor(IEditorInput element) {</TD></TR><TR CLASS="z"><TD CLASS="l">653</TD><TD>                ModelInfo result = (ModelInfo) fModelInfoMap.get(element);</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="12">654</A></TD><TD>                return result;</TD></TR><TR><TD CLASS="l">655</TD><TD>        }</TD></TR><TR><TD CLASS="l">656</TD><TD> </TD></TR><TR><TD CLASS="l">657</TD><TD>        private ModelInfo getModelInfoFor(IStructuredModel structuredModel) {</TD></TR><TR CLASS="z"><TD CLASS="l">658</TD><TD>                ModelInfo result = null;</TD></TR><TR CLASS="z"><TD CLASS="l">659</TD><TD>                if (structuredModel != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">660</TD><TD>                        ModelInfo[] modelInfos = (ModelInfo[]) fModelInfoMap.values().toArray(new ModelInfo[0]);</TD></TR><TR CLASS="z"><TD CLASS="l">661</TD><TD>                        for (int i = 0; i &lt; modelInfos.length; i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">662</TD><TD>                                ModelInfo info = modelInfos[i];</TD></TR><TR CLASS="z"><TD CLASS="l">663</TD><TD>                                if (structuredModel.equals(info.fStructuredModel)) {</TD></TR><TR CLASS="z"><TD CLASS="l">664</TD><TD>                                        result = info;</TD></TR><TR CLASS="z"><TD CLASS="l">665</TD><TD>                                        break;</TD></TR><TR><TD CLASS="l">666</TD><TD>                                }</TD></TR><TR><TD CLASS="l">667</TD><TD>                        }</TD></TR><TR><TD CLASS="l">668</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">669</TD><TD>                return result;</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><TD CLASS="l">673</TD><TD>         * Method loadModel.</TD></TR><TR><TD CLASS="l">674</TD><TD>         * </TD></TR><TR><TD CLASS="l"><A NAME="14">675</A></TD><TD>         * @param input</TD></TR><TR><TD CLASS="l">676</TD><TD>         * @return IStructuredModel</TD></TR><TR><TD CLASS="l">677</TD><TD>         */</TD></TR><TR><TD CLASS="l">678</TD><TD>        public IStructuredModel loadModel(IStorageEditorInput input) {</TD></TR><TR CLASS="z"><TD CLASS="l">679</TD><TD>                return loadModel(input, false);</TD></TR><TR><TD CLASS="l">680</TD><TD>        }</TD></TR><TR><TD CLASS="l">681</TD><TD> </TD></TR><TR><TD CLASS="l">682</TD><TD>        /**</TD></TR><TR><TD CLASS="l">683</TD><TD>         * Method loadModel.</TD></TR><TR><TD CLASS="l">684</TD><TD>         * </TD></TR><TR><TD CLASS="l">685</TD><TD>         * @param input</TD></TR><TR><TD CLASS="l"><A NAME="15">686</A></TD><TD>         * @param logExceptions</TD></TR><TR><TD CLASS="l">687</TD><TD>         * @return IStructuredModel</TD></TR><TR><TD CLASS="l">688</TD><TD>         */</TD></TR><TR><TD CLASS="l">689</TD><TD>        public IStructuredModel loadModel(IStorageEditorInput input, boolean logExceptions) {</TD></TR><TR CLASS="z"><TD CLASS="l">690</TD><TD>                String id = calculateID(input);</TD></TR><TR CLASS="z"><TD CLASS="l">691</TD><TD>                if (id == null) {</TD></TR><TR CLASS="z"><TD CLASS="l">692</TD><TD>                        return null;</TD></TR><TR><TD CLASS="l">693</TD><TD>                }</TD></TR><TR><TD CLASS="l">694</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">695</TD><TD>                InputStream contents = null;</TD></TR><TR><TD CLASS="l">696</TD><TD>                try {</TD></TR><TR CLASS="z"><TD CLASS="l">697</TD><TD>                        contents = input.getStorage().getContents();</TD></TR><TR><TD CLASS="l">698</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">699</TD><TD>                catch (CoreException noStorageExc) {</TD></TR><TR CLASS="z"><TD CLASS="l">700</TD><TD>                        if (logExceptions)</TD></TR><TR CLASS="z"><TD CLASS="l">701</TD><TD>                                Logger.logException(NLS.bind(SSEUIMessages._32concat_EXC_, new Object[]{input.getName()}), noStorageExc);</TD></TR><TR><TD CLASS="l">702</TD><TD>                }</TD></TR><TR><TD CLASS="l">703</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">704</TD><TD>                IStructuredModel model = null;</TD></TR><TR><TD CLASS="l">705</TD><TD>                try {</TD></TR><TR><TD CLASS="l">706</TD><TD>                        // first parameter must be unique</TD></TR><TR CLASS="z"><TD CLASS="l">707</TD><TD>                        model = StructuredModelManager.getModelManager().getModelForEdit(id, contents, null);</TD></TR><TR CLASS="z"><TD CLASS="l">708</TD><TD>                        model.setBaseLocation(calculateBaseLocation(input));</TD></TR><TR><TD CLASS="l">709</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">710</TD><TD>                catch (IOException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">711</TD><TD>                        if (logExceptions)</TD></TR><TR CLASS="z"><TD CLASS="l">712</TD><TD>                                Logger.logException(NLS.bind(SSEUIMessages._32concat_EXC_, new Object[]{input}), e);</TD></TR><TR><TD CLASS="l">713</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">714</TD><TD>                finally {</TD></TR><TR CLASS="z"><TD CLASS="l">715</TD><TD>                        if (contents != null) {</TD></TR><TR><TD CLASS="l">716</TD><TD>                                try {</TD></TR><TR CLASS="z"><TD CLASS="l">717</TD><TD>                                        contents.close();</TD></TR><TR><TD CLASS="l">718</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">719</TD><TD>                                catch (IOException e) {</TD></TR><TR><TD CLASS="l">720</TD><TD>                                        // nothing</TD></TR><TR><TD CLASS="l">721</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">722</TD><TD>                                catch (Exception e) {</TD></TR><TR CLASS="z"><TD CLASS="l">723</TD><TD>                                        Logger.logException(e);</TD></TR><TR><TD CLASS="l">724</TD><TD>                                }</TD></TR><TR><TD CLASS="l">725</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">726</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">727</TD><TD>                return model;</TD></TR><TR><TD CLASS="l">728</TD><TD>        }</TD></TR><TR><TD CLASS="l">729</TD><TD> </TD></TR><TR><TD CLASS="l">730</TD><TD>        /**</TD></TR><TR><TD CLASS="l"><A NAME="16">731</A></TD><TD>         * @param input</TD></TR><TR><TD CLASS="l">732</TD><TD>         * @return</TD></TR><TR><TD CLASS="l">733</TD><TD>         */</TD></TR><TR><TD CLASS="l">734</TD><TD>        private IStructuredModel selfCreateModel(IEditorInput input) {</TD></TR><TR CLASS="z"><TD CLASS="l">735</TD><TD>                return loadModel((IStorageEditorInput) input);</TD></TR><TR><TD CLASS="l">736</TD><TD>        }</TD></TR><TR><TD CLASS="l">737</TD><TD> </TD></TR><TR><TD CLASS="l">738</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="7e.html">org.eclipse.wst.sse.ui.internal</A>]</TD></TR><TR><TD CLASS="tl"><A HREF="http://www.eclemma.org/support.html">EMMA 2.0.5312 EclEmma Fix 1</A> (C) Vladimir Roubtsov</TD></TR></TABLE></BODY></HTML>